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Писать об устройствах типа ВетоиШ 
Вох, не упомянув при этом имени 
швейцарского ученого Даниила Бернулли, 
так же невозможно, как, рассказывая об 
истории авиации, не вспомнить братьев 
Райт. Хотя впрочем, если не к авиации, 
то к аэродинамике почетный член 
Петербургской Академии Наук 
Д. Бернулли имеет непосредственное 
отношение. 


Из истории ВегпоиІІі 


Еще из курса средней школы 
известен закон течения идеальной 
жидкости или газа, описываемый 
уравнением Бернулли: давление 

на поверхность, создаваемое 
потоком движущейся жидкости 
или газа, зависит от скорости 
этого потока. Причем, чем 
быстрее движется газ (или 
жидкость), тем меньше давление 
на поверхность. Этот, на первый 
взгляд, достаточно скучный 
феномен уже давно имеет яркое 
практическое применение. Бла- 
годаря тому, что профиль несущей 
поверхности самолета выполнен 
определенным образом, скорость 
движения воздуха над верхней 
частью поверхности выше, чем 
под нижней. Результирующая 
разница давлений и обуславливает 
подъемную силу. 

Специалисты американской 
фирмы Іотеда нашли красивое ре- 
шение для минимизации расстоя- 


ния между магнитным слоем носи- 
теля и головкой записи /считыва- 
ния, используя для регулирования 
этого расстояния известное соот- 
ношение Бернулли. Внешне новый 
носитель данных — ВегпоиІІі 
Сагігісіяе — выглядит как увели- 
ченная до 5,25 дюймов обычная 

з, 5-дюймовая дискета. Движение 
воздуха в этой конструкции созда- 
ется благодаря быстрому враще- 
нию диска. Неподвижный диск с 
магнитным носителем прогибается 
под тяжестью собственного веса, 

и, поскольку он расположен ниже 
головки, отдаляется от нее. При 
выборе оптимальной скорости вра- 
щения магнитный слой носителя и 
головку разделяет крошечная про- 
слойка воздуха (три миллионных 
миллиметра). Головка “летит" над 
рабочей поверхностью носителя и, 
как следствие, отсутствует ее из- 
нос. При снижении количества 
оборотов, например, из-за отклю- 


чения электропитания, расстояние 
между поверхностью магнитного 
носителя и универсальной голов- 
кой автоматически увеличивается. 

Рассматриваемые ниже накопи- 
тели, использующие эффект Бер- 
нулли (К.етоѵаЫе Сагігіб^е Огіѵе, 
К.СО), представляют уже второе 
поколение подобных устройств, 
используя в качестве сменного но- 
сителя — картриджа — теперь 
уже 5,25-дюймовые кассеты, вме- 
сто прежних 8-дюймовых. Это мо- 
дели ВегпоиІІі Вох II, ВегпоиІІі 
202 и ВегпоиІІі II 44. Версии этих 
устройств имеют как встроенное 
(іпіегпаі зиЪзузІет), так и вне- 
шнее исполнение (ехіегпаі зиЬ- 
зузіеш). Первые две модели КСО 
позволяют использовать кар- 
триджи емкостью 20 Мбайт, по- 
следняя — 44 Мбайта. 

Некоторые характеристики этих 
устройств приведены на рис.1. 
Следует пояснить, что устройство 
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ИЗ ИСТОРИИ ВЕКШІІШ 



Устройства 

Параметры 

ВегпоиШ Вох II 
44 М 

ВегпоиШ 

202 

ВегпоиШ II 
20 М 

Форматированная 
емкость, Мб 

44,5 

21,4 

. 21,4 

Время выборки, мс 

22 

24 

28 

Скорость передачи 
данных, Мб/с 

<5,5 

< 4.9 

< 3,9 

Чередование секторов 

1:1 

1:1 

1:1 

Время старт/стопа, с 

5 

7 

7 

Тип контроллера 

8С8І 

8С8І 

8С8І 

Буфер контроллера, Кб 

32 

8 

8 

Метод записи 

КП 

ЯП 

ЯП 

Код коррекции 

Рид-Соломон 

48 бит ЕСС 

48 бит ЕСС 

Среднее время без- 
отказной работы, лет 

12 

12 

12 


Рис. 1. 


ВегпоиШ 202 является 

улучшенным вариантом ВегпоиШ 
Вох II, это касается как скорости 
передачи данных, так и времени 
выборки. Причем владельцы 
накопителей ВегпоиШ Вох II могут 
путем простой модернизации плат 
улучшить рабочие характеристики 
накопителей до значений 
параметров ВегпоиШ 202. 

В комплект поставки, помимо 
одного или двух ЯСО, кабелей, 
документации и программ, входит 
плата Нозі-адаптера для компью- 
тера (например, ІВМ РС). Она 
имеет половинную ширину (соот- 
ветственно, использует 8- разряд- 
ную шину данных). В общем слу- 
чае на плате находятся два десят- 
ка микросхем, 50-контактный 
разъем интерфейса ЗСЗІ, микро- 
переключатели и поле для уста- 
новки перемычек. Тип 

адаптера — РС2В/50 или 

РС2/50 — определяется наличием 
на плате микросхем ОЗУ (ЯАМ), 
ПЗУ (КОМ) и микросхемы 
управляющей логики, по- 

зволяющие выполнять загрузку с 
системного картриджа ЯСО. Но об 
этом чуть позже. 


Микропереключатели на плате 
определяют область адресов адап- 
тера для компьютера 

(340Н...375Н), номер используемо- 
го канала прямого доступа к памя- 
ти (ОМА 1 или 3), способ вво- 
да/вывода данных (программный 
или с использованием ОМА), ко- 
личество подсоединенных ЯСО 
(один или два). Перемычки на 
плате устанавливают начальный 
адрес ЯОМ (в диапазоне 
С8000Н...Е4000Н), при этом воз- 
можно использовать одно из 15 
различных значений в указанном 
диапазоне. Это объясняется тем, 
что разные типы ІВМ- 
совместимых компьютеров могут 
использовать некоторые из этих 
областей памяти. Например, в 
компьютерах с процессором І8088, 
область памяти, начинающаяся с 
С8000Н, обычно занята под ПЗУ 
ВІ08 жесткого диска. В некоторых 
РС/АТ под этот ВІ05 занята 
память начиная с адреса Е0000Н. 

Подсоединение двух ЯСО к 
Н озі-адаптеру производится по 
принципу “дэйзи-цепочки 44 (даізу- 
сНаіпіп^) — Мазіег (управляю- 
щий) и Зіаѵе (управляемый), то 


есть. Пассивное устройство 
управляется через кон- 
троллер активного. 

Драйвер ЯС0.8ѴЗ, по- 
ставляемый фирмой Іошеда в 
составе программного обес- 
печения, позволяет использо- 
вать накопители с версией 
М3 008 не ниже 3.0. Если 
Нозі-адаптер для ЯСО имеет 
тип РС2В/50, то имеется 
возможность выполнить за- 
грузку компьютера с систем- 
ного картриджа. Правда, 
здесь имеются и другие огра- 
ничения. Во-первых, извест- 
но, что Р08Т ВІ08 позволя- 
ет выполнять загрузку 008 
либо с устройства А:, либо с 
устройства С:, таким обра- 
зом, чтобы стартовать с 
ЯСО, необходимо (иногда 
даже физически) отключить 
имеющийся винчестер, вос- 
принимаемый обычно как 
устройство С:. Во-вторых, 
версии 008 ниже 4.0 под- 
держивают разделы жесткого 
диска размером не более 
32 Мбайт. И хотя драйвер 
ЯСО.ЗѴ8 позволяет работать с 44- 
Мбайтными картриджами под ран- 
ними версиями 008, для того, 
чтобы загрузиться с такой 
кассеты, необходимо разбить ее на 
разделы в 32 Мбайта (загрузоч- 
ный) и 12 Мбайт (увы! никак уже 
не используемый). Поскольку пять 
утилит для М8-И08 заменены для 
Іоше^а ЯСО собственными утили- 
тами (рис.2.), форматирование 
картриджа или раздела произво- 
дится утилитой ЯСО РОЯМАТ с 
ключом /8 (перенос системных 
файлов). На системном разделе 
кассеты, помимо файлов системы, 
должны присутствовать файлы 
ЯСО.ЗѴЗ, ССЖРІС.8ѴЗ и 
АІІТОЕХЕС.ВАТ. При этом файл 
СОЫРІС.8ѴЗ должен содержать 
минимум две строки 

ОЕѴІСЕ * ЯСО.ЗѴЗ 

ВІІРРЕЯ8 = 8 (конечно, мож- 
но и больше) 

В файле АІІТОЕХЕС.ВАТ реко- 
мендуется установить команду 
ѴЕЯІРѴ ОЫ для проверки опера- 
ций ввода/вывода. 
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М3 ЭОЗ утилиты 

ЯСЭ утилиты 

ВАС КУР 

всо васкор 

0І8КС0РУ 

КС0 СОРУ 

Р0І5К 

ВСО РАВТІТІ0Ы 

РОВМАТ 

ВСО РОВМАТ 

ВЕЗТОВЕ 

ВСО ВЕЗТОВЕ 


Рис. 2. 


При использовании КС О не- 
сомненный интерес представ- 
ляет процедура резервного ко- 
пирования диска (Васкир), осу- 
ществляемая собственной 

утилитой К.СО ВАСКИ Р. Эта 
утилита дает возможность 
использовать две разновид- 
ности этой операции: И$аЫе 
Васкир и АгсНіѵаІ Васкир. 
Метод ИзаЫе Васкир эф- 
фективен, когда емкость вин- 
честера меньше, чем емкость 
картриджа КСО, поскольку 
происходит непосредственное 
копирование файлов. В случае ис- 
пользования АгсНіѵаІ Васкир, 
перед последующим использова- 
нием файлов они должны быть 
восстановлены утилитой К.СП 
КЕ8ТОКЕ. Этот метод ре- 
комендуется в случае, когда ем- 
кость используемого винчестера 
больше емкости одного картриджа 
КСЭ. Решение о том, какой из 
методов применить в конкретном 
случае, зависит и от количества 
дублируемых файлов. Если их 
суммарный размер не превосходит 
44 Мбайт (для ВегпоиШ Вох 44), 
то копирование файлов быстрее 
выполняется при использовании 
ІІзаЫе Васкир, в противном 
случае эффективнее окажется 
АгсНіѵаІ Васкир. 


Следует также отметить, что 
фирма Іоте^а обеспечивает совме- 
стимость своих изделий с сетевым 
программным обеспечением фир- 
мы Ыоѵеіі. Тип используемого 
компьютера практически не на- 
кладывает ограничения на приме- 
нение устройств типа ВегпоиШ 
Вох (при использовании соответ- 
ствующего адаптера). Это могут 
быть РС/ХТ, РС/ХТ286, РС/АТ, 
РС/АТ386, Р8/2 (модели 60, 80), 
Сотрац РогіаЫе 286, Сотрая 
ЭезкРго, Тапёу 3000, Ііпізуз и т.д. 
Например, журнал Мікгосошриіег 
2еіізсНгіН упоминает о 70 проте- 
стированных моделях компьюте- 
ров. 

Особенности устройств типа 
ВегпоиШ Вох, такие как емкость, 


скорость передачи данных (на 
уровне параметров жестких 
дисков), возможность смены 
кассеты носителя, высокая 
надежность хранения данных и 
практическая нечувствитель- 
ность к механическим воздей- 
ствиям, обуславливают и 
сферы их применения. Так, 
например, применение КСО в 
наших, зачастую коллективно- 
персональных “писишках 44 , да- 
ет неплохой шанс сделать их 
действительно персональными. 
Конфиденциальность и сохран- 
ность ценных данных будут га- 
рантированы. Если использовать 
КСЭ как устройство для загрузки 
ЭОЗ, то вероятность появления 
вирусов в Вашей системе сводится 
практически к нулю. Применение 
ЯСЭ как дополнения к винчестеру 
для хранения, например, больших 
графических массивов, требующих 
оперативного доступа, практи- 
чески не имеет альтернатив (если 
исключить сменные жесткие дис- 
ки). Фирма Іоше^а гарантирует 
долговечность хранения данных на 
кассетах в течение 5 лет. 


С.Трофимов 
Л. Борзенко 


Электронная почта сети ЯЕЬСОМ 

Электронная почта сети Кеісот создана Демос/* и ИВЦ ИАЭ им. 
Курчатова, и зарегистрирована Международным центром в Стенфор- 
де (США). Сегодня еще можно включиться в национальную и в 
мировую систему электронной почты, став пользователем сети 
КЕЬСОМ. Демос/* обеспечит подключение к сети, а так же, при 
необходимости, поставит оборудование: компьютер, телефонный мо- 
дем и программное обеспечение 

Модемы М^-5, 2400/ 4800 Ьрз встроенные и внешние, адаптирован- 
ные к отечественным линиям, эффективно работающие в почтовой 
сети. Коррекция ошибок, компрессия данных, Науез совместимый, 
аттестован Минсвязи СССР. Гарантийное обслуживание 1 год. 






ДЕМОС/*: 113035 Москва, Овчинниковская наб. дом 6 А, 
телефон: 231-21-29, 231-63-95; Рах: (095) 233.5016; Е-таіІ: іп!о@Нд.с1ето$.$и 

По вопросам заключения договоров на подключение к сети Кеісол обращаться по телефонам Демоса/* и телефону ИВЦ: 196-72-50. 
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БЕЗОПАСНОСТЬ КОМПЬЮТЕРНЫХ СИСТЕМ 



М* продолжаем публикацию статьи о безопасности 
компьютерных систем, начатую в прошлом номере . Когда 
журнал с первой частью статьи был уже в типографии, мы 
узнали о некоторых интересных событиях, имевших место в 
нашей стране летом этого года. Более подробно об этом вы 
можете прочитать в еженедельнике “Коммерсантъ" №40 (90) 
от 30 сентября-6 октября 1991 года, мы же лишь вкратце 
напомним вам суть дела. Случилось именно то, о чем 
КомпьютерПресс предупреждал уже давно, и наиболее 
настойчиво — в предыдущем номере. Во Внешэкономбанке СССР 
начальником отдела вычислительного центра было совершено 
крупное хищение валюты. Кража проводилась с помощью 
компьютерной программы, автором которой был сам 
преступник. Эта программа использовалась в банке уже 10 лет. 
Самое потрясающее во всей этой истории то, что никто 
происшедшему особенно не удивился, а главное — не 
обеспокоился. Соответствующий отклик это событие вызвало 
только в узких компьютерных кругах, занимающихся 
компьютерной безопасностью. Ни банковские работники, ни 
многочисленные брокерские конторы на событие почЫи не 
отреагировали. Они по-прежнему не понимают или не хотят 
понимать, что ходят по лезвию ножа. Вот уж, поистине, 
олимпийское спокойствие. Видно, нашего мужика ничем не 
прошибешь — он не крестится и после того, как грянул гром. 

И, между прочим, совершенно напрасно. Нет никаких сомнений, 
что компьютерная преступность, как и всякая другая 
преступность в нашей стране, будет расти. И мы к этому 
совершенно не готовы. У нас любой мало-мальски 
квалифицированный пользователь может залезть в 
компьютерную сеть, устроить там погром, получить 
конфиденциальную информацию и спокойно с достоинством 
удалиться. У нас ведь нет специалистов по компьютерной 
преступности! У нас нет соответствующих законов! 
Следователь по делу кражи в ВЭБ признался, что ничего не 
смыслит в компьютерах. Интересно, много ли они там 
нарасследуют? Ведь компьютерная программа могла 
переводить деньги не только на те счета, которые 
“ засветились ". Кто в этом сможет разобраться? Да, видно, 
чудеса в нашей стране еще только начинаются. Мы, как те 
глупцы, предпочитаем учиться на своих собственных ошибках, 
не признавая чужого опыта. Ну что ж, будем надеяться , что 
естественный отбор все же поможет продвинуться в бизнесе 
людям умным, а не только хитрым и пронырливым. Как 
говорится, что бог ни делает — все к лучшему. 
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Безопасность 
компьютерных систем 


“По-настоящему безопасной можно 
считать лишь систему , которая 
выключена , замурована в бетонный 
корпус , заперта в помещении со 
свинцовыми стенами и охраняется 
вооруженным караулом , — но и в 
этом случае сомнения не оставляют 
меня 14 . 

Юджин X. Спаффорд 

2. Безопасность программ 

Условимся, что под термином “программа" мы в 
равной степени будем понимать обычные программы 
пользователей; специальные программы, рассчитанные 
на нарушение безопасности системы; а также разно- 
образные системные утилиты и коммерческие при- 
кладные программы, которые отличаются более высо- 
ким профессиональным уровнем разработки и, тем не 
менее, могут содержать отдельные недоработки, по- 
зволяющие захватчикам атаковать системы. 

Программы могут порождать проблемы двух типов: 
они, во-первых, могут перехватывать и модифициро- 
вать данные в результате действий пользователя, ко- 
торый к этим данным не имеет доступа; и, во-вторых, 
используя упущения в защите компьютерных систем, 
программы могут или обеспечивать доступ к системе 
пользователям, не имеющим на это права, или блоки- 
ровать доступ к системе законных пользователей. 

К сожалению, количество возможных слабых точек, 
которые могут содержаться в той или иной программе, 
значительно превышает число известных технологий 
устранения экспозиций. Это обусловлено двумя при- 
чинами: 

- во-первых, качество программы всегда не превышает 
квалификации ее разработчика: очевидные экспози- 
ции и нарушения могут быть выявлены и устранены 
достаточно легко, однако, чем выше уровень подго- 
товки программиста, тем более неявными (даже для 
него) становятся допускаемые им ошибки и тем бо- 
лее тщательно и надежно он способен скрыть умыш- 


ленные механизмы, разработанные для нарушения 
безопасности системы; 

- во-вторых, имеет место трудно разрешимый компро- 
мисс между эффективностью и удобством компью- 
терной системы в работе и степенью обеспечения в 
ней требований безопасности. Чем более высокие 
требования предъявляются к безопасности системы, 
тем большее количество ресурсов системы затрачива- 
ется на обеспечение этих требований, тем сильнее 
снижается производительность системы и увеличи- 
вается сроки решения задач, наконец, тем неудобнее 
работать в данной системе пользователям. С другой 
стороны, чем больше ресурсов выделяется для реше- 
ния текущих задач, тем меньше возможностей по 
обеспечению должного уровня безопасности. 

В основном небезопасность программ состоит в том, 
что они могут быть использованы как средства полу- 
чения критичной информации (данных), циркулиру- 
ющей в системе, тем более, что данные в компьютер- 
ной системе обычно хранятся в виде, непонятном для 
большинства людей. 

Впрочем, целью атаки могут быть и сами про- 
граммы. Причин тому несколько: 

1. В современном мире программы могут быть това- 
ром, приносящим немалую прибыль, особенно тому, 
кто первый начнет тиражировать программу в ком- 
мерческих целях и оформит авторские права на нее. 
Поэтому опасность похищения почти готовой про- 
граммы конкурентом — не такая уж надуманная 
возможность. 

2. Программы могут становиться также объектом 
атаки, имеющей целью модифицировать эти про- 
граммы некоторым образом, что позволило бы в бу- 
дущем провести атаку на другие объекты системы. 
Особенно часто объектом атак такого рода стано- 
вятся программы, реализующие функции защиты си- 
стемы. 

Рассмотрим несколько типов программ и приемы, 
которые наиболее часто используются для атак про- 
грамм и данных. 
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БЕЗОПАСНОСТЬ КОМПЬЮТЕРНЫХ СИСТЕМ 


2.1 Как залезть в программу 

Как залезть в программу? Очень просто — через 
люк! 

Люком называется не описанная в документации на 
программный продукт возможность работы с этим про- 
граммным продуктом. Сущность использования люков 
состоит в том, что при выполнении пользователем не- 
которых не описанных в документации действий он 
получает доступ к возможностям и данным, которые в 
обычных условиях для него закрыты (в частности — 
выход в привилегированный режим). 

Люки чаще всего являются результатом забывчиво- 
сти разработчиков. В процессе разработки программы 
разработчики часто создают временные механизмы, 
облегчающие ведение отладки за счет прямого доступа 
к отлаживаемым частям продукта. Пусть, например, 
для начала работы с продуктом требуется выполнить 
некоторую последовательность действий, предусмот- 
ренных алгоритмом, — ввести пароль, установить зна- 
чения некоторых переменных и т.п. При нормальной 
работе продукта эти действия имеют определенный 
смысл. Но во время отладки, когда разработчику необ- 
ходимо тестировать некоторые внутренние части про- 
граммы и волей-неволей приходится выполнять ту же 
операцию входа добрый десяток — а то и более — раз 
на дню, безобидные в общем-то правила, затрудня- 
ющие тем не менее доступ к отлаживаемым частям, 
начинают не на шутку раздражать. Что же делает 
программист? Правильно: в течение получаса он про- 
граммирует некоторый дополнительный механизм, не 
предусмотренный изначальным алгоритмом про- 
граммы, но позволяющий не выполнять надоедливых 
действий или выполнять их автоматически — напри- 
мер, при нажатии определенной клавиши 
(комбинации клавиш) или при вводе определенной 
последовательности символов. Все — люк готов! 

По окончании отладки большинство люков убира- 
ется из программы; но люди есть люди — зачастую 
они забывают о существовании каких-то мелких 
“лючков". Иногда, правда, разработчики сознательно 
оставляют люки в своих продуктах, особенно в ранних 
версиях, когда весьма вероятна возможность доработки 
продукта. 

Одним из наиболее показательных примеров 
использования “забытых" люков является, пожалуй, 
широко известный в компьютерном мире инцидент с 
вирусом Морриса. Одной из причин, обусловивших 
возможность распространения этого вируса, была 
ошибка разработчика программы электронной почты, 
входящей в состав одной из версий операционной си- 
стемы ІШІХ, приведшая к появлению малозаметного 
лючка. Для вас, наверное, будет небесполезно знать, 
что американские специалисты оценивают ущерб, на- 
несенный в результате этого инцидента, более чем в 
100 миллионов долларов. 

Люки могут образовываться также в результате ча- 
сто практикуемой технологии разработки программ- 
ных продуктов “сверху вниз". При этом программист 


приступает к написанию сразу управляющей 
программы, заменяя предполагаемые в будущем 
подпрограммы так называемыми “заглушками" — 
группами команд, имитирующими или просто 
обозначающими место подсоединения будущих 
подпрограмм. В процессе разработки по мере 
готовности реальных подпрограмм эти подпрограммы 
заменяют соответствующие заглушки. В теории 
моментом завершения разработки конечной 
программы по такой технологии можно считать 
момент замены последней заглушки реальной 
подпрограммой (при условии, что все подпрограммы 
отлажены и синхронизированы). 

В действительности дело обстоит несколько слож- 
нее. Вся беда в том, что авторы часто оставляют за- 
глушки в конечном программном продукте, передава- 
емом в эксплуатацию. Делают это порой неумыш- 
ленно: например, на ранних стадиях разработки пред- 
полагалось наличие в конечном продукте некоторой 
подпрограммы, однако в процессе разработки выясни- 
лось, что эта подпрограмма в силу каких-либо причин 
не нужна. Но заглушка-то на предполагавшемся месте 
подключения подпрограммы осталась! Более того, уда- 
лить заглушку, не заменяя ее подпрограммой, бывает 
весьма сложно. Все это может спровоцировать про- 
граммиста на то, чтобы оставить такую заглушку на 
месте “до лучших времен". 

Возможен вариант, когда заглушки оставляются в 
конечной программе сознательно, в расчете на под- 
ключение в дальнейшем к работающей программе но- 
вых подпрограмм, реализующих некоторые новые воз- 
можности, либо предполагая возможное подключение 
к программе тестирующих средств для более точной 
настройки программы. Будет ли пользователь данной 
программы приобретать эти “новые возможности", 
обратится ли он когда-нибудь к разработчику про- 
граммы с просьбой более тонко настроить его де- 
тище — это еще под вопросом, а ведь заглушки-то 
стоят! Кто может дать гарантию, что в один прекрас- 
ный момент такой заглушкой кто-нибудь не восполь- 
зуется для подключения к программе совсем иной 
подпрограммы, работающей в интересах этого "кого- 
нибудь", а не законного пользователя? 

Наконец, еще одним распространенным источником 
люков является так называемый "неопределенный 
ввод". 

Допустим, некто предлагает вам программу, кото- 
рой можно управлять с помощью определенных ко- 
манд или даже просто путем ввода в ответ на запросы 
программы символов "У" ("Да") или "Ы" ("Нет"). А 
что произойдет, если вы в ответ на запрос введете, 
предположим, "А" или вместо верной команды введете 
какую-либо абракадабру? Если программа написана 
хорошо, то такие случаи должны вызывать появление 
на экране сообщения типа "НЕВЕРНЫЙ ВВОД" и 
повтор запроса. 

Однако не так уж редка ситуация, когда программа 
создается неопытным программистом, исходящим из 
предположения, что пользователи будут работать с его 
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программой всегда корректно. В этом случае реакция 
программы на неопределенный ввод может быть в 
лучшем случае непредсказуемой (когда при повторном 
вводе той же неверной команды программа реагирует 
каждый раз по-разному); гораздо хуже, если про- 
грамма в результате одинакового “неопределенного" 
ввода выполняет некоторые повторяющиеся дей- 
ствия — это дает потенциальному захватчику возмож- 
ность планировать свои действия по нарушению безо- 
пасности, 

В любом случае существует потенциальная возмож- 
ность нарушения безопасности системы. 

Неопределенный ввод — частная реализация ПРЕ- 
РЫВАНИЯ. То есть в общем случае захватчик может 
умышленно пойти на создание в системе некоторой 
нестандартной ситуации, позволившей бы ему выпол- 
нить необходимые действия. Например, он может 
искусственно вызвать аварийное завершение про- 
граммы, работающей в привилегированном режиме, с 
тем, чтобы перехватить управление, оставшись в этом 
привилегированном режиме. Классический пример та- 
кого рода люков — ассемблерные команды 5РІЕ и 
8РАЕ в ЕС ЭВМ, допускающие в определенных ситу- 
ациях перехват пользователем (или его программой) 
управления в режиме супервизора. 

Борьба с возможностью прерывания (в терминоло- 
гии безопасности) в конечном итоге выливается в 
предусмотрение при разработке программ комплекса 
механизмов, образующих так называемую “защиту от 
дурака". Смысл этой защиты состоит в том, чтобы га- 
рантированно отсекать всякую вероятность обработки 
неопределенного ввода и разного рода нестандартных 
ситуаций (в частности, ошибок). Короче, качественная 
программа должна работать корректно и не приводить 
к появлению возможности нарушения безопасности 
компьютерной системы, даже если с самой програм- 
мой работают некорректно — например, если за кла- 
виатурой терминала случайно оказалась обезьяна. 

Таким образом, люк (или люки) может присутство- 
вать в программе ввиду того, что программист: 

1 ) забыл удалить его; 

2) умышленно оставил его в программе для обеспече- 
ния тестирования или выполнения оставшейся части 
отладки; 

3) умышленно оставил его в программе в интересах 
облегчения окончательной сборки конечного про- 
граммного продукта; 

4) умышленно оставил его в программе с тем, чтобы 
иметь скрытое средство доступа к программе уже по- 
сле того, как она вошла в состав конечного продукта. 

В первом случае люк — неумышленная, но серьез- 
ная брешь в безопасности системы. Во втором и 
третьем случаях люк — серьезная экспозиция безо- 
пасности системы. Наконец, в последнем случае 
люк — первый шаг к атаке системы. 

В любом случае люки — это возможность получить 
управление вашей системой в обход защиты. 


2.2 "Бойтесь данайцев, дары приносящих!" 

Существуют программы, реализующие, помимо 
функций, описанных в документации, и некоторые 
другие функции, в документации не описанные. Такие 
программы называются троянскими конями. 

Например, вы запускаете какую-то нужную вам 
программу — графический пакет, расчетную задачу 
или игру, наконец, — а через некоторое время обна- 
руживаете, что в вашей директории исчезли все 
файлы. Поскольку кроме запуска известной вам про- 
граммы вы ничего другого не делали, вполне вероятно, 
что вы заподозрите что-то неладное и решите запу- 
стить ту же программу в другой (лучше специально 
для этого созданной) директории. Если эффект повто- 
рится — вы имеете дело с "троянским конем" в ком- 
пьютерном исполнении. 

Далеко не всегда обнаружить троянского коня бы- 
вает так просто — вероятность обнаружения тем 
больше, чем очевиднее результаты действия троян- 
ского коня. А если задачей троянского коня является 
не удаление ваших файлов, а изменение их защиты? 
Явно вы этого не увидите, но каково будет ваше удив- 
ление, когда через некоторое время выяснится, что 
конфиденциальные данные, содержавшиеся в одном из 
ваших файлов (например, проект важного документа), 
стали известны всем. Проверяете наличие файла — на 
месте, проверяете защиту файла — а оказывается, его 
может читать любой! 

Однако такие фиксированные результаты представ- 
ляют очень опасную для троянского коня угрозу 
разоблачения его деятельности и, соответственно, 
обнаружения. Более сложный троянский конь может 
быть запрограммирован таким образом, чтобы по 
изменении защиты файлов (в нашем примере) пода- 
вать захватчику (лицу, заинтересованному в срабаты- 
вании троянского коня) некоторый условный сигнал о 
доступности файлов; после выдачи сигнала троянский 
конь некоторое время выжидает, а затем возвращает 
защиту файлов в исходное состояние. 

Такой алгоритм позволяет захватчику в течение не- 
которого времени делать с вашими файлами все, что 
угодно, и никаких следов атаки после этого не оста- 
ется. Вы же остаетесь в полном счастливом неведении, 
т.е. с носом. 

2.3 Какая неожиданность! 

"Логической бомбой" обычно называют программу 
или даже участок кода в программе, реализующий не- 
которую функцию при выполнении определенного 
условия. 

Я понимаю, что такое определение достаточно рас- 
плывчато, поэтому попытаюсь его пояснить. 

Прежде всего "логическая бомба" отлйчается от 
других программ тем, что, "взрываясь", она реализует 
функцию, неожиданную или, хуже того, нежеланную 
для пользователя. Например, удаляет некоторые дан- 
ные или разрушает некоторые системные структуры 


2 Зак. 2503 
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данных. Впрочем, функция логической бомбы может 
быть и более безобидной: например вывод на экран 
терминала или на принтер некоторого сообщения 
шутливого или оскорбительного характера. 

Бомбы, существующие в виде отдельных программ, 
обычно имеют малопонятные или, наоборот, любопыт- 
ные имена. Ничего не подозревающий пользователь, 
получивший подобный “сюрприз", каким-либо обра- 
зом, естественно, пробует запустить программу, чтобы 
понять, что она делает — вот тут-то и начинается са- 
мое интересное! Классическим примером бомбы явля- 
ется программа, распространенная в американских 
компьютерных сетях под названием К.оскѵібео. После 
ее запуска на экране дисплея можно увидеть мультип- 
ликационные картинки с американской рок-певицей 
Мадонной, причем показ завершается выдачей сооб- 
щения следующего содержания: “Только идиот 

использует свой компьютер для того, чтобы рассмат- 
ривать видеозвезд! “. Во время демонстрации бомба 
удаляет себя, но заодно удаляет и все файлы на до- 
ступных для нее дисках. 

Есть также основания предполагать, что не слиш- 
ком широко известный инцидент с остановкой глав- 
ного конвейера на Горьковском автозаводе был также 
не чем иным, как “взрывом" “логической бомбы". 

Естественно, поняв, что представляет собой про- 
грамма- “пода рок", пользователь удаляет ее, но это за- 
частую уже не имеет значения: бомба-то взорвалась. А 
уж разрушения в ваши данные она может внести са- 
мые сокрушительные: это определяется только уров- 
нем подготовки и изощренностью автора бомбы. 

Более сложным является случай, когда программа, 
осуществляющая некоторую законную обработку, со- 
держит в себе участок кода, который срабатывает при 
выполнении в системе некоторых условий, например 
при наступлении определенной даты или при обнару- 
жении файла с определенным именем. Такие 
вкрапления в тело обычных программ также можно 
считать “логической бомбой". 

Мировая компьютерная общественность достаточно 
хорошо знакома с логическими бомбами. Логическая 
бомба является одним из излюбленных способов мести 
программистов компаниям, которые их уволили или 
чем-либо обидели. При этом чаще всего срабатывание 
бомбы ставится в зависимость от установки в системе 
даты — так называемые “часовые" бомбы. Это очень 
удобно: допустим, программист знает, что его уволят 1 
марта; в таком случае он может установить “часовую" 
бомбу на взрыв, допустим, 6 июля или даже на Рож- 
дество, когда сам он будет уже вне пределов досяга- 
емости для пострадавшей компании*. 

Ориентируя бомбу на установку определенной даты, 
можно также закладывать бомбы впрок: например, 


* В этом отношении интересна высказанная одним из 
администраторов систем мысль, что при увольнении 
системного программиста будет лучше, если глава фирмы 
проводит его до дверей офиса, вежливо попрощается и подаст 
пальто. 


можно определить, что бомба должна сработать 30 
февраля. Поскольку такой даты не существует, бомба 
не взорвется до тех пор, пока знающий о ней 
злоумышленник преднамеренно (или ни о чем не 
догадывающийся оператор системы — по ошибке) не 
установит системные часы в соответствующее поло- 
жение. 

2.4 Колбаса и компьютер 

Речь пойдет о биче банковских компьютерных си- 
стем — атаке “салями". 

Чтобы понять смысл такой атаки, полезно вспо- 
мнить технологию изготовления известного сорта кол- 
басы, которая создается путем соединения в общее це- 
лое множества мелких кусочков мяса. Получается до- 
статочно вкусно. 

Теперь рассмотрим смысл компьютерной атаки. В 
банковских системах ежедневно производятся тысячи 
операций, связанных с безналичными расчетами, пе- 
реводами сумм, отчислениями и т.д. Во многих из та- 
ких операций возникает проблема вычисления различ- 
ного рода долей от некоторой величины. Вычислить 
необходимый процент можно с разной степенью точ- 
ности, и поэтому еще при разработке систем устана- 
вливается правило округления (или усечения), исполь- 
зуемое при выполнении всех операций. 

Классическим примером атаки салями является, 
возможно, вымышленная история о вычислении доли в 
6,5% от 102,87 долл, для 31 дня. Несложные вычис- 
ления дают: 

31 / 365 * .065 * 102.87 = 0.5495726 долл. 

С точки зрения банка, различающего в качестве са- 
мой маленькой величины только целый цент, эта ве- 
личина не имеет смысла, также как вряд ли кто-ни- 
будь из нас сможет доступно объяснить, что такое 
“полкопейки". Поэтому в банках принято правило, по 
которому величины, превышающие половину цента, 
округляются с избытком (или просто округляются) до 
целого цента, а величины менее половины цента про- 
сто отбрасываются. 

Вся хитрость состоит в том, как запрограммировать 
обработку отбрасываемых долей и округлений. Можно, 
конечно, просто удалять несущественные величины. 
Но можно и не удалять эти величины, а накапливать 
их постепенно на некоем специальном счете. Там пол- 
цента, тут полцента... — а в сумме? Как свидетель- 
ствует практика, сумма, составленная буквально из 
ничего, за пару лет эксплуатации “хитрой" программы 
в среднем по размеру банке, может исчисляться тыся- 
чами долларов. 

Можно сказать, что атака салями — компьютерная 
реализация известной поговорки “С миру по нитке — 
голому рубаха". 

Компьютерные вычисления по природе склонны к 
мелким погрешностям, особенно при одновременной 
обработке больших и маленьких величин. С другой 
стороны, для различных практических нужд человеку 
требуется различная точность вычислений. Расплачи- 
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ваясь, например, в такси, вы можете позволить себе 
поправку счета на размер “чаевых 44 , но рассчитывая 
орбиту искусственного спутника, вы будете заинтере- 
сованы в вычислении всех величин с точностью “до 
энного знака после запятой 44 . Однако обработка дроб- 
ных величин на ЭВМ связана с достаточно сложными 
вычислениями. Именно ввиду этой изначальной слож- 
ности работы с дробными величинами обнаружить в 
программе код, реализующий атаку салями, бывает 
весьма непросто. А это в свою очередь объясняет регу- 
лярное появление сообщений о все новых и новых 
атаках этого типа. 

2.5 Скрытые каналы 

Теперь поговорим о программах, передающих 
информацию лицам, которые в обычных условиях эту 
информацию получать не должны. Называются такие 
необычные способы извлечения информации скры- 
тыми каналами. 

В тех системах, где ведется обработка критичной 
информации, программист не должен иметь доступа к 
обрабатываемым программой данным после начала 
эксплуатации этой программы. Например, банковский 
программист не должен иметь доступа к именам или 
счетам вкладчиков и клиентов, как не должен знать 
порядка обслуживания клиентов. В процессе отладки 
программы разработчику допускается предоставление 
ограниченного объема реальных данных для проверки 
работоспособности программы, но предоставление ре- 
альных данных после сдачи программы в эксплуата- 
цию не имеет оправдания. 

Из факта обладания некоторой служебной инфор- 
мацией можно извлечь достаточно немалую выгоду, 
хотя бы элементарно продав эту информацию 
(например, список клиентов) конкурирующей фирме. 
Поэтому нетрудно предположить, что кто-либо из со- 
трудников будет заинтересован в том, чтобы иметь 
возможность такую информацию получать. 

Достаточно квалифицированный программист 
всегда может найти способ скрытой передачи инфор- 
мации; при этом программа, предназначенная для со- 
здания самых безобидных отчетов может быть немного 
сложнее, чем того требует задача. Для скрытой пере- 
дачи информации можно с успехом использовать раз- 
личные элементы формата “безобидных 44 отчетов, на- 
пример, разную длину строк, пропуски между стро- 
ками, наличие или отсутствие служебных заголовков, 
управляемый вывод незначащих цифр в выводимых 
величинах, количество пробелов или других символов 
в определенных местах отчета и т.д. 

Например, определенную информацию может нести 
появление в отчете вместо служебного заголовка 
“ТОТАЬ 44 другого заголовка — “ТОТАЬЗ 44 . Разница 
всего в один символ, но именно его наличие или 
отсутствие и может быть сигналом осведомленному о 
канале захватчику (например, о том, что в системе 
появился файл с определенным именем). В данном 
случае имеет место 1 -битовый скрытый канал, так как 


за один раз передается один бит информации 
(наличие или отсутствие символа “8“). 

Однако возможна ситуация, когда захватчик не бу- 
дет иметь доступа ко всем отчетам, создаваемым 
“хитрой 44 программой, и таким образом он будет ли- 
шен возможности пользоваться своим скрытым кана- 
лом непосредственно. • 

В таком случае программист может обеспечить, на- 
пример, вызов в определенных ситуациях более безо- 
пасной программой, непосредственно обрабатывающей 
интересующие захватчика данные, менее безопасной 
программы, которой и будут переданы критичные дан- 
ные. А уж вызванная программа может создавать за- 
маскированный, внешне “безобидный 44 отчет, доступ- 
ный для просмотра захватчику. 

Еще более сложным может быть случай, когда за- 
хватчик не имеет возможности просматривать замас- 
кированные отчеты или обеспечивать вызов подпрог- 
рамм-шпионов, но имеет возможность доступа к ком- 
пьютеру во время работы интересующей его про- 
граммы. В такой ситуации возможно создание специ- 
ального массива данных непосредственно в оператив- 
ной памяти компьютера, куда программа, содержащая 
скрытый канал, будет пересылать критичную инфор- 
мацию. Причем, опять же, информация может быть 
представлена в виде служебных символов, старт-стоп- 
ных сигналов для магнитных лент, символов управле- 
ния консолью и т.д. 

Как видно из приведенных примеров, для получе- 
ния относительно небольших объемов информации за- 
хватчик вынужден проделать достаточно большую ра- 
боту. Поэтому скрытые каналы наиболее применимы в 
ситуациях, когда захватчика интересует даже не со- 
держание информации, а, допустим, факт ее наличия 
(например, наличие в банке расчетного счета с опре- 
деленным номером). Можно предположить и более 
изощренную ситуацию: с помощью скрытого канала 
захватчик получит сигнал о появлении в системе 
файла с определенным именем, что в свою очередь 
служит признаком работы в системе некоторого про- 
цесса, позволяющего провести атаку иного типа. 

2.6 Жадность — порок! 

Большинство методов нарушения безопасности на- 
правлены на то, чтобы получить доступ к данным, не- 
допускаемый системой в нормальных условиях. 
Однако не менее интересным для захватчиков явля- 
ется доступ к управлению самой компьютерной систе- 
мой или изменение ее качественных характеристик. 
Это может потребоваться для того, чтобы явно исполь- 
зовать компьютерную систему в своих целях (хотя бы 
для бесплатного решения своих задач) либо просто 
заблокировать систему, сделав ее недоступной другим 
пользователям. Такой вид нарушения безопасности си- 
стемы называется “отказом в обслуживании 44 или 
“отказом от пользы 44 . 

Некоторые компьютеры, особенно в исследователь- 
ских центрах, имеют так называемые “фоновые 44 за- 
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дачи, постоянно решаемые, но с очень маленьким 
приоритетом. Обычно это задачи, требующие для ре- 
шения очень большого машинного времени, но не осо- 
бенно срочные (типа вычисления числа е или Пи с 
очень большой степенью точности). Низкий приоритет 
делает возможным решение этих задач только при 
условии, что в системе нет задач с более высоким 
приоритетом. Однако по недосмотру либо в результате 
ошибки, либо умышленно приоритет такой “фоновой 44 
задачи может быть существенно повышен: в этом 
случае бывшая “тихоходная 44 задача захватывает 
процессор в монопольное использование, блокируя 
выполнение всех других вычислений. 

Такого рода программы, захватывающие некоторый 
ресурс в монопольное использование, называются 
жадными программами. Ведь чтобы остановить выпол- 
нение какого-либо задания, вовсе не обязательно 
захватывать именно процессор. 

Например, если известно, что на некотором этапе 
задача, которую нужно заблокировать, должна выпол- 
нять вывод на печать некоторого отчета, можно забло- 
кировать доступ к принтеру. В таком случае оператор 
системы будет видеть, что обработка заданий проходит 
“нормально 44 — процессор-то не заблокирован и дру- 
гие задачи нормально решаются — и так до тех пор, 
пока не прибежит разгневанный хозяйн заблокирован- 
ной задачи в сопровождении администратора системы. 

Изобрести подходящую “долгоиграющую 44 задачу 
для того, чтобы намертво заблокировать систему, не- 
сложно — достаточно запрограммировать в обычной 
программе явный или неявный бесконечный цикл. 

В явном виде бесконечный цикл можно определить, 
поставив условием окончания цикла условие, которое 
никогда не будет выполнено. Ну, например, запро- 
граммировать выполнение цикла, пока 1 больше 0. 
Да, единица всегда будет больше нуля! Таким 
образом, цикл будет выполняться хоть до второго 
пришествия. 

В неявном виде цикл можно организовать с по- 
мощью двух команд перехода, которые передают 
управление друг другу. Это что-то вроде лемовских 
“сепулек 44 и “сепулькарий 44 . 

Бороться с бесконечными циклами можно с помо- 
щью имеющейся в большинстве систем возможности 
устанавливать предельное количество машинного вре- 
мени для решения данной задачи. В таком случае по 
исчерпании задачей выделенного лимита времени, си- 
стема автоматически останавливает задачу. Однако, 
во-первых, установленный лимит можно обойти или 
постоянно изменять, а во-вторых, сославшись на дли- 
тельность решения задачи, можно потребовать от ад- 
министратора системы вообще снять какие-либо вре- 
менные ограничения для вашей задачи. 

Кроме того, существует еще одна тонкость в исчис- 
лении машинного времени. Дело в том, что машинное 
время измеряется в единицах времени, затраченного 
центральным процессором на выполнение данной за- 
дачи. Таким образом, время ожидания задачей некото- 
рого события — например окончания операции вво- 


да/вывода — не учитывается. В некоторых системах, 
если задача запрашивает выполнение операции вво- 
да/вывода, то на время ожидания этой задачей завер- 
шения запрошенной операции система “выключает 44 
счетчик времени процессора для данной задачи. Но 
можно ведь создать программу ввода/вывода с беско- 
нечным циклом! В таком случае остановится и внеш- 
няя программа, вызвавшая подпрограмму-ловушку. 

Можно упомянуть также о знакомой программистам 
возможности вхождения двух процессов в клинч. 

Допустим, в системе решаются две задачи — А и Б. 
Предположим также, что они имеют следующие алго- 
ритмические участки: 

задача А задача Б 


захватить ресурс 1 захватить ресурс 2 

захватить ресурс 2 захватить ресурс 1 

освободить ресурс 1 освободить ресурс 2 

Теперь попытаемся представить, что произойдет, 
если обе задачи выйдут на выполнение этих участков 
одновременно. При этом задача А захватит в исполь- 
зование ресурс 1 (допустим, принтер); задача Б в то 
же время захватит ресурс 2 (предположим, плоттер). 
Далее задача А попробует захватить ресурс 2, но он-то 
уже захвачен задачей Б! Аналогично и с задачей Б, 
которой требуется захватить ресурс 1, уже захвачен- 
ный задачей А. 

Казалось бы, чего проще — пускай одна из задач 
освободит ресурс — и конфликт разрешится. Но в 
том-то весь секрет, что освобождение ресурса в обеих 
задачах зависит от выполнения захвата второго (в 
каждой задаче своего) ресурса, т.е. не выполнив за- 
хвата, задача не освободит другого ресурса. 

Такое безвыходное положение, весьма похожее на 
ситуацию с двумя баранами на одном мосту из извест- 
ной детской сказки, и называется клинчем. 

Клинч может возникать случайно, в силу неудачно 
сложившихся обстоятельств; может возникнуть в ре- 
зультате низкого качества программирования; но нет, 
однако, принципиальной невозможности провокации 
неким злоумышленником ситуации, чреватой вхожде- 
нием в клинч. 

В большинстве современных систем существуют 
специальные средства разрешения такого рода кон- 
фликтов. Более того, в настоящее время уже при про- 
ектировании систем предусматривается наличие встро- 
енных механизмов, нацеленных на выявление и 
предотвращение угрожающих ситуаций. И тем не ме- 
нее угроза клинча остается. 

Насколько опасной может быть блокировка ком- 
пьютерной системы? 

Прежде всего, спросите военных, насколько опасной 
может быть блокировка компьютера, управляющего 
различного рода системами раннего обнаружения или 
той же противовоздушной оборону. 

Можно поинтересоваться у врачей, насколько серь- 
езными могут быть последствия блокировки компьюте- 
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ров, осуществляющих мониторинг больных в реанима- 
ционном отделении. 

Уже из этих примеров становится очевидным, что 
“отказ от обслуживай ия“ чрезвычайно опасен для так 
называемых систем реального времени — систем, 
управляющих некоторыми технологическими процес- 
сами, осуществляющих различного рода синхрониза- 
цию и т.д. 

2.7 Компьютерные вирусы 

Компьютерные вирусы — тема для отдельного 
очень интересного и очень длинного разговора. 

Серьезного отношения компьютерные вирусы по- 
требовали к себе относительно недавно; настолько не- 
давно, что американский институт стандартов до сих 
пор не дал четкого определения компьютерного ви- 
руса, благодаря чему в трудах и работах 
специалистов-компьютерщиков царит полйейший 
плюрализм в трактовке этого термина. 

В последнее время распространилось следующее 
определение: 

КОМПЬЮТЕРНЫЙ ВИРУС — набор команд 
(программных или иных), который производит и рас- 
пространяет свои копии в компьютерных системах 
и/или компьютерных сетях и преднамеренно выпол- 
няет некоторые действия, нежелательные для закон- 
ных пользователей систем. 

Рассмотрим подробнее ключевые элементы опреде- 
ления, чтобы лучше понять суть явления. 

Компьютерный вирус — набор команд. Ко- 
манды, составляющие тело вируса, могут иметь самую 
различную природу. Сюда могут входить команды ка- 
кого-либо языка(-ов) программирования (наиболее 
распространенный случай), микропрограммные ин- 
струкции, управляющие символы и комбинации в те- 
лекоммуникационных сообщениях, различного рода 
параметры, а также команды языка управления зада- 
ниями. Таким образом, перспективное каноническое 
определение вируса не должно ограничивать среду 
существования вируса. 

Компьютерный вирус распространяется. Ка- 
ноническое определение вируса не должно также 
ограничивать способы распространения вируса. Важно 
то, что вирус может репродуцировать себя в одной или 
нескольких компьютерных системах**. 

Существенно также то, что вирус в принципе мо- 
жет распространять набор команд, отличающийся по 
форме или содержанию от оригинала. Короче, вирус 
со временем может эволюционировать. 

Компьютерный вирус выполняет нежелатель- 
ные действия. Попадая тем или иным способом в 


** Кстати, именно способность саморазмножаться отличает 
программу-вирус от логической бомбы. 


вашу Систему, вирус самокопирует себя в различные 
места памяти системы, а затем (либо одновременно с 
этим) производит в вашей системе изменения, в луч- 
шем случае не приводящие к катастрофическим для 
вас последствиям (например, высвечивание на экране 
терминала некоторого сообщения), а в худшем — де- 
лающие вашу систему неработоспособной. Заметим, 
что большинство вирусов изначально небезобидны. 

Так как вирус самостоятельно обеспечивает свое 
размножение и распространение, вам, в случае обна- 
ружения вами вируса, необходимо проверить всю вашу 
систему, уничтожая копии вируса. Если вам удалось 
уничтожить все копии вируса, вы можете сказать, что 
вылечили вашу систему; в противном случае уцелев- 
шие копии снова саморазмножатся и все неприятности 
повторятся сначала. 

Своим названием компьютерные вирусы обязаны 
определенному сходству с вирусами естественными: 
способности к саморазмножению; высокой скорости 
распространения; избирательности поражаемых систем 
(каждый вирус поражает только определенные си- 
стемы или однородные группы систем); способности 
“заражать 44 еще незараженные системы; трудности 
борьбы с вирусами и т.д. В последнее время к этим 
особенностям, характерным для вирусов компьютер- 
ных и естественных, можно добавить еще и постоянно 
увеличивающуюся быстроту появления модификаций 
и новых поколений вирусов. Только если в случае 
вирусов естественных эту скорость можно объяснить 
могуществом и изобретательностью природы, то 
вирусы компьютерные скоростью возникновения новых 
штаммов обязаны исключительно недосмотру или 
бредовым идеям людей определенного склада. 

Приведем пример подпрограммы-вируса. Она со- 
стоит из псевдокоманд 008 и подпрограмм — малень- 
ких внутренних программ (составляющие их инструк- 
ции хранятся отдельно от главной программы), вы- 
полняющих некоторые специальные функции всякий 
раз, когда к ним обращаются. 

ІНіз: - ГіпсШІе 
ШАО(Ош) 

Іос: = зеагсН(1Ыз) 

іпзегШос) 

ЗТОКЕОЫз) 

Подпрограмма под названием ПпсІПІе обращается к 
каталогу выполняемых файлов или программ на диске, 
берет произвольное имя файла и присваивает имя 
этого файла переменной ІНіз (этот). 

В следующей строке программы используется псев- 
докоманда Б08 ШАП (загрузить), с помощью 
которой файл помещается в оперативную память 
компьютера. 

Другая подпрограмма под названием зеагсН (поиск) 
просматривает только что загруженную программу в 
поисках инструкции, которая могла бы послужить 
подходящим местом, куда можно занести вирус. Когда 
процедура зеагсН находит такую инструкцию, она 
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определяет соответствующий номер строки и присва- 
ивает его в качестве значения переменной Іос. 

Теперь все готово для того, чтобы подпрограмма-ви- 
рус могла проникнуть в произвольно выбранную из 
каталога программу. Подпрограмма іпзегі (вставить) 
заменяет выбранную инструкцию другой (например 
такой, как вызов подпрограммы). Замененная ин- 
струкция передает управление блоку команд, состав- 
ляющих главное тело подпрограммы-вируса, которая 
присоединяется к концу программы. Затем к концу 
добавленной подпрограммы присоединяется инструк- 
ция, возвращающая управление “зараженной" про- 
грамме, на инструкцию, следующую за вставленной. 

Таким образом, когда выполняется подпрограмма- 
вирус, выполняется также и подмененная инструкция 
зараженной программы. Исходная программа работает 
так, будто ничего особенного не произошло. Однако, 
на самом деле, подпрограмма-вирус воспользовалась 
каким-то мгновением, чтобы захватить власть над 
средствами операционной системы и прицепить свою 
копию к еще одной программе, хранящейся на диске. 

Приведенный пример демонстрирует лишь один из 
приемов, используемых авторами вирусов. В насто- 
ящее время специалисты выделили и другие приемы, 
отличающиеся друг от друга идеями и изощренностью 
выполнения. 

В широком потоке литературы по проблеме вирусов, 
хлынувшей на нас в последнее время, приводится 
множество классификаций и описаний вирусов. Так 
что интересующихся этой проблемой всерьез я с чув- 
ством глубокого облегчения отсылаю к специальным 
публикациям, большей частью, правда, далеких от со- 
вершенства и законченности. 

2.8 Как возникают угрозы 

Все рассмотренные выше виды опасных програм- 
мных приемов иногда обозначают единым терми- 
ном — “электронные ловушки“. 

Заслуживает внимания вопрос о том, как эти ло- 
вушки появляются. 

В простейшем случае программист с самого начала 
разработки программы предусматривает наличие в ней 
какой-либо электронной ловушки, предположим тро- 
янского коня. Скомпилировав программу, он отдает 
свое изделие для использования в вычислительный 
центр или другому пользователю, не предоставляя при 
этом исходного кода программы. Анализировать дво- 
ичный код программы — дело весьма непростое, на 
несколько порядков более сложное, чем анализ текста 
программы на одном из языков программирования 
(хотя и исходный текст можно основательно запу- 
тать). Поэтому весьма велика вероятность того, что 
программа сразу поступит в эксплуатацию, чего, соб- 
ственно, захватчику и нужно. 

Зная о такой нехитрой технике обмана, многие 
центры принимают для обработки лишь исходные тек- 
сты программ. При этом компиляция и эксплуатация 
программы происходит в самом вычислительном цен- 


тре, но только после анализа на наличие в программе 
электронных ловушек. Конечно, непременным усло- 
вием для установления такой дисциплины является 
наличие в составе сотрудников центра высококлас- 
сного программиста, способного выполнить анализ 
исходного кода программы. 

Еще раз отмечу, что поиск электронной ловушки по 
исходному тексту — очень непростая задача. Не стоит 
считать захватчика наивным: можно не сомневаться, 
что он предпримет все, чтобы тщательно замаскиро- 
вать опасный код. Во всяком случае не ждите, что 
текст ловушіси будет выделен комментарием типа: 
“Здесь приготовлен сюрприз!". 

Существует много способов затруднить чтение про- 
граммы. Например, можно отбросить всякие правила 
структурного программирования и поступить прямо 
противоположным образом — начать активно исполь- 
зовать в программе переходы из одной части в другую. 
Такие перескоки по тексту очень утомляют при чте- 
нии, поскольку трудно при этом не сбиться и не поте- 
рять смысл алгоритма. 

Далее, существует немало способов вызова подпрог- 
рамм, одна из которых и может оказаться ловушкой. 
Вызов может осуществляться одной командой — по- 
пробуйте выделить эту команду среди* десятков, а то и 
сотен других команд. Кроме того, вызов может быть и 
неявным: например, путем прямого занесения в счет- 
чик команд адреса точки входа ловушки. В других си- 
стемах это можно сделать путем установки указателя 
системного стека на соответствующую команду и т.д. 
Степень изощренности зависит от квалифицированно- 
сти захватчика. 

Если все же ловушка не выделена в некоторую са- 
мостоятельную подпрограмму, можно рассредоточить 
код ловушки по всему тексту программы. Код ловушки 
разбивается на пары команд, причем вторая команда 
каждой пары — команда перехода на следующую 
пару. 

Еще пример? Можно запрограммировать ловушку 
таким образом, чтобы она использовала участки кода 
внешней программы, но в определенной последова- 
тельности и с добавлением небольших серий команд, 
разбросанных по всему тексту программы. Сами по 
себе эти добавочные команды могут выполнять внешне 
невинные, чаще всего бесполезные, с точки зрения 
анализирующего специалиста, действия. Легко ли 
разобраться в таком месиве команд? Как различить, 
где тело полезной программы, а где — раковая опу- 
холь ловушки? 

Кроме того, следует иметь в виду, что захватчик 
может внедрить электронную ловушку в уже прове- 
ренный исходный код программы, находящийся 
внутри центра. Это лишний раз подтверждает необхо- 
димость средств ограничения доступа пользователей к 
различным ресурсам системы, в частности — к тек- 
стам программ. 

К сожалению, злоумышленное внесение кодов элек- 
тронных ловушек в исходный текст программ — не 
единственный способ внедрить ловушку. Захватчиком 
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может» оказаться высококлассный специалист, способ- 
ный ввести код ловушки непосредственно в двоичный 
код программ (а многие вирусы, например, сами обес- 
печивают внедрение своих копий в исполняемые 
образы программ). Работа с двоичным исполняемым 
кодом программы требует весьма высокого уровня под- 
готовки и надлежащих навыков в работе со специаль- 
ными программными средствами — это своего рода 
“высший пилотаж“ программирования. Модификация 
двоичного кода может быть выполнена либо во время 
хранения программы на магнитном носителе в проме- 
жутках между ее вызовами, либо даже во время вы- 
полнения непосредственно в памяти машины. 

Следует понимать, что в чистом виде описанные 
выше приемы встречаются достаточно редко. Гораздо 
чаще в ходе атаки используются отдельные элементы 
разных приемов. Например, “логическая бомба“ явля- 
ется фактически другой стороной “троянского коня“: 
ведь по сути внешняя программа, содержащая 
“логическую бомбу 44 , является ничем иным, как 
“троянским конем 44 . Вирусы вообще являются квинтэс- 
сенцией всевозможных методов нарушения безопасно- 
сти. Иногда складывается впечатление, что все 
остальные способы атаки появились только для того, 
чтобы обеспечить возникновение компьютерных виру- 
сов. Посудите сами: одним из самых частых и излюб- 
ленных способов распространения вирусов является 
метод “троянского коня 44 . От “логической бомбы 44 ви- 
русы отличаются только возможностью размножаться 
и обеспечивать свой запуск — так что многие вирусы 
можно считать особой формой “логических бомб 44 . Для 
атаки системы вирусы активно используют разного 
рода “люки 44 . Реализовывать вирусы могут самые раз- 
нообразные пакости, в том числе и атаку салями. 
Кроме того, успех атаки одного вида часто способ- 
ствует снижению “иммунитета 44 системы, создает бла- 
гоприятную среду для успеха атак других видов. За- 
хватчики это знают и активно используют указанное 
обстоятельство. 

Все вышесказанное имеет целью подтолкнуть вас к 
закономерному и единственно верному выводу. Бо- 
роться даже с частным видом нарушений безопасно- 
сти — электронными ловушками — как и с любыми 
другими видами нарушений, можно, только используя 
в комплексе все физические, логические и организа- 
ционные средства и методы обеспечения безопасности. 

3. Безопасность 
в операционных системах 

Операционная система — “душа 44 любой компью- 
терной системы — в принципе является очень боль- 
шой и сложной программой. Так что многие слабости 
программ, о которых шла речь выше, присущи и опе- 
рационным системам. 

Однако есть ряд качеств, которые заставляют выде- 
лить вопросы обеспечения безопасности операционных 
систем в особую категорию. 


Прежде всего операционная система часто содержит 
ряд встроенных механизмов, прямо или косвенно 
влияющих на безопасность всех программ и данных, 
работающих и обрабатываемых в среде данной опера- 
ционной системы. 

Помимо этого, размер и сложность операционной 
системы как программы делает качественно более 
сложной атаку на поражение операционной системы. 

Чтобы испортить настроение администратору си- 
стемы, вовсе не обязательно специально разрабатывать 
одну из описанных выше электронных ловушек. Нане- 
сти серьезный ущерб системе — и тем самым нару- 
шить ее безопасность — можно и с помощью самых 
обычных программ или утилит. Например, удалить 
важный для кого-то файл можно с помощью одной 
команды операционной системы. Можно вообще 
отформатировать все доступные носители с помощью 
стандартной системной утилиты, уничтожив тем са- 
мым всю хранившуюся на них информацию и даже 
саму систему. Прочитать данные — те, которые вам 
читать не положено, — легче всего с помощью тексто- 
вого редактора. 

Таким образом, мы подошли к одной из централь- 
ных проблем в обеспечении безопасности: проблеме 
несанкционированного (неавторизованного) доступа и 
способам его предотвращения. Вся проблема заключа- 
ется в обеспечении такого порядка работы, при кото- 
ром систему мог бы использовать только тот, кому ее 
разрешено использовать; чтобы каждый законный 
пользователь работал только со “своими 44 данными и 
не мог исказить, прочитать или удалить из системы 
данные, принадлежащие другому пользователю (если 
на то нет согласия хозяина); чтобы каждый законный 
пользователь мог выполнять только те операции, кото- 
рые ему разрешено выполнять администратором си- 
стемы. 

В самом деле, вполне естественным является стрем- 
ление не допустить работы в системе посторонних 
лиц: вы же не пускаете случайных прохожих в свой 
дом. Не менее естественно желание пользователей 
иметь гарантии, что их личные данные никто по 
ошибке или с умыслом не удалит, не исказит, не про- 
читает и т.д. 

Кроме того, имеет прямой смысл предоставлять 
каждому новому пользователю для начала только са- 
мый необходимый набор средств, без которых он во- 
обще работать не сможет — хотя бы в целях его же 
собственной безопасности. Вы же не даете ребенку 
молоток, справедливо опасаясь, что он попробует им 
шарахнуть по телевизору (или уж, по крайней мере, 
следите за ним). Начинающий пользователь для си- 
стемы представляет не меньшую угрозу, чем ребенок 
для телевизора. По незнанию, неопытности или не- 
осторожности пользователь может сотворить самые 
невероятные вещи: от простого удаления собственных 
данных (ну, с этим-то сталкивался практически каж- 
дый, кто имел дело с компьютером) до приведения в 
неработоспособное состояние всей системы в целом 
либо отдельных ее компонентов. 
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БЕЗОПАСНОСТЬ КОМПЬЮТЕРНЫХ СИСТЕМ 


БЕЗОПАСНОСТЬ КОМПЬЮТЕРНЫХ СИСТЕМ 

Словарь терминов 


Ассехх — доступ — 1) в обработке 

данных: взаимодействие между 
субъектом и объектом, обеспе- 
чивающее передачу информа- 
ции между ними; 2) в физи- 
ческой безопасности: возмож- 
ность входа на защищенную 
территорию. 

Ассехх сопігоі — управление досту- 
пом — в сетях или их компо- 
нентах: задачи, выполняемые 
аппаратурой, программным 
обеспечением и администраци- 
ей, с целью отслеживания вы- 
полняемых в системе операций, 
целостности данных, доступа и 
модификаций системных за- 
писей, выполнения пользовате- 
лями идентификации и предос- 
тавление пользователям досту- 
па. 

Ассехх регіосі — период доступа — 
временной интервал, в течение 
которого действуют права дос- 
тупа. В основном этот период 
определяется в днях или неде- 
лях. 

АссошиаЫІИу — отслеживаемость — 
возможность для ответственных 
лиц восстанавливать ход нару- 
шения или попытки нарушения 
безопасности информационной 
системы. 

АссгесНіаІіоп — аккредитация — авто- 
ризация и санкционирование 
обработки критичных данных в 
операционной среде информа- 
ционной системы или сети. Ре- 
шение об аккредитации выно- 
сится после получения всеми 
лицами из технического персо- 
нала сертификата, подтвержда- 
ющего возможность этих лиц 
работать с защищенными сис- 
темами. При этом предвари- 
тельно должно бытъ подтверж- 
дено соответствие проекта са- 
мой системы и его конкретной 
реализации набору заранее оп- 
ределенных технических требо- 
ваний. Все эти условия служат 
единственной цели — обеспе- 
чению степени безопасности 
адекватной уровню критичнос- 
ти данных. 

АЦаск — атака — нарушение безопас- 
ности информационной систе- 
мы, позволяющее захватчику 
управлять операционной сре- 
дой. 

Аікііі — контроль — образ действий, 
позволяющий получать незави- 


симый обзор и анализ систем- 
ных записей и активности сис- 
темы с целью установления ее 
текущего состояния безопаснос- 
ти. 

АисШ ігаіі — след контроля — записи 
о транзакциях, выполняемых в 
системе, которые (записи) в со- 
вокупности документируют ход 
обработки информации в систе- 
ме, что в свою очередь позволя- 
ет проследить (провести трас- 
сировку) его вперед — от ис- 
ходных транзакций до создава- 
емых в процессе их работы за- 
писей и/или отчетов — а так- 
же назад — от конечных запи- 
сей/отчетов до исходных транз- 
акций. Последовательность за- 
писей, составляющих след кон- 
троля, позволяет определить 
источники возникновения 

транзакций в системе и после- 
довательность их выполнения 
системой. 

Ашіііілв — ведение контроля — про- 
цедуры управления системой, 
необходимые для обеспечения 
нормальной работы системы и 
выполнения имеющихся задач, 
а также для обеспечения эф- 
фективности работы и эффек- 
тивности использования ресур- 
сов информационной системы. 
Ведение контроля может осу- 
ществляться лицами, отличны- 
ми от лиц, непосредственно от- 
вечающих за работу системы и 
решение конкретных задач. 

АиіЬепіісаііоп — аутентификация — 
1) процедура идентификации 
или проверки полномочности 
узлов, инициаторов или лиц 
для доступа к определенной ка- 
тегории информации; 2) план, 
разрабатываемый для обеспече- 
ния защиты от незаконных пе- 
редач информации за счет ус- 
тановления санкционированно- 
сти потоков информации, сооб- 
щений, узлов или инициаторов. 

АиЦюгігаііоп — авторизация — пол- 
номочия, устанавливаемые ад- 
министратором системы для 
конкретных лиц, позволяющие 
последним использовать транз- 
акции, процедуры или всю сис- 
тему в целом. 

Соттипісаііопх «есигііу — безопас- 
ность коммуникаций — аутен- 
тификация телекоммуникаций 
за счет принятия мер по пред- 


отвращению предоставления 
неавторизованным лицам кри- 
тичной информации, которая 
может быть выдана системой в 
ответ на телекоммуникацион- 
ный запрос. 

Сотргошіае — компрометация — уте- 
ря критичной информации, ли- 
бо получение ее неавторизован- 
ными для этого субъектами 
(лицами,- программами, про- 
цессами и т.д.) 

СотріНег зесигііу — компьютерная 
безопасность — комплекс тех- 
нологических и административ- 
ных мер, применяемых в отно- 
шении аппаратных средств, 
программ, данных и служб с 
целью обеспечения доступно- 
сти, целостности и конфиден- 
циальности связанных с ком- 
пьютерами ресурсов; сюда же 
относятся и процедуры провер- 
ки выполнения системой опре- 
деленных функций в строгом 
соответствии с их запланиро- 
ванным порядком работы. 

СопГісІепііаІііу — конфиденциаль- 
ность — некоторая классифи- 
кация данных, получение либо 
использование которых неавто- 
ризованными для этого лицами 
может стать причиной серьез- 
ного ущерба для организации. 

Со5і-ЬепеП( алаіуаіа — анализ за- 
трат/выгоды — стадия в раз- 
работке или развитии системы, 
на которой определяется стои- 
мость обеспечения защиты дан- 
ных в информационной систе- 
ме; иногда под этой стоимостью 
подразумевают ущерб, который 
может быть нанесен в случае 
утери или компрометации дан- 
ных, подлежащих защите. 

Соѵегі сЬаппеІ — скрытый канал — 
канал коммуникации, позволя- 
ющий процессу передавать ин- 
формацию путем, нарушаю- 
щим политику безопасности, 
реализуемую в данной системе. 

Ба(а іп(е&гі(у — целостность дан- 
ных — состояние, при котором 
данные, представленные в ком- 
пьютере, в точности соответст- 
вуют данным в исходных доку- 
ментах и при этом не могут 
быть подвержены неумышлен- 
ным или умышленным искаже- 
ниям или разрушениям. 

Баіа ргоіесііоп — защита данных — 
средства защиты данных от 
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случайных или умышленных 
нежелательных модификаций, 
разрушений или разглашений. 

Баі а зесигііу — безопасность дан- 
ных — защита данных от неав- 
торизованных, случайных, 
умышленных или возникших 
по халатности модификаций, 
разрушений или разглашений. 

Баіа зесигііу оГПсег (ББО) — офицер 
безопасности — лицо, отвеча- 
ющее за обеспечение безопас- 
ности обработки данных в сис- 
теме и за противодействие по- 
пыткам неразрешенного ис- 
пользования данных. 

БОБ Сиісіеііпез Гог Сотриіег 
Бесигііу — совокупность пра- 
вил, установленных Министерс- 
твом Обороны США (БОБ - 
Берагітепі оГ БеГепсе) для оп- 
ределения степени безопаснос- 
ти узлового программного обес- 
печения — операционных сис- 
тем, узловых средств контроля 
доступа и т.д. 

Рогшаі зесигііу роіісу тобеі — фор- 
мальная модель политики без- 
опасности — политика без- 
опасности, выраженная точным 
математическим образом, 

включающим начальное состоя- 
ние системы, способы перехода 
системы из одного состояния в 
другое и определение “безопас- 
ного* 4 состояния системы. 

Наскіпз — неавторизованная попытка 
доступа к базе данных узла. 
Часто этот термин используется 
в отношении лиц, пытающихся 
получить доступ к узловой базе 
данных с удаленного узла за 
счет обхода (обмана) средств 
контроля доступа в сети. 

ІсіепііЛсаІіоп — идентификация — 
процесс анализа персональных, 
технических или организацион- 
ных характеристик или кодов 
для получения (предоставле- 
ния) доступа к компьютерным 
ресурсам. 

Іпсііѵісіиаі ассоипіаЪіЙГу — индивиду- 
альный учет — комплекс мер, 
за счет которых идентифика- 
ция пользователя может быть 
использована для определения 
возможности доступа пользова- 
теля к машинам, материалам и 
т.п.; правила предоставления 
пользователю времени, методов 
и режимов доступа. 

ІпГогтаііоп зесигііу — безопасность 
информации — защита инфор- 
мационных массивов от слу- 


чайных, либо преднамеренных, 
но неавторизованных разглаше- 
ний, модификаций или разру- 
шений, либо невозможность об- 
работки этой информации. 

ІпГогтаІіоп зузіет зесигііу — без- 
опасность информационной 
системы — совокупность эле- 
ментов, необходимых для обес- 
печения адекватной защиты 
компьютерной системы, вклю- 
чая аппаратные/программные 
функции, характеристики и 
средства; операционные и 
учетные процедуры, средства 
управления доступом на 
центральном компьютере, уда- 
ленных компьютерах и теле- 
коммуникационных средствах; 
административные меропри- 
ятия, физические конструкции 
и устройства; управление пер- 
соналом и коммуникациями. 

Іпіезгііу — целостность — состояние, 
в котором данные или програм- 
мы используются установлен- 
ным образом, обеспечивающим 
устойчивую работу системы; 
автоматическое восстановление 
в случае обнаружения системой 
потенциальной ошибки; авто- 
матическое использование аль- 
тернативных компонентов вме- 
сто вышедших из строя. При- 
мером является дублирование 
важных файлов с тем, чтобы в 
случае обнаружения ошибки 
или утери оригинального фай- 
ла использовать его копию. 
Другим примером является 
поддержание двух и более пу- 
тей доступа к устройству хра- 
нения. 

ЬоорНоІе — дыра, брешь — програм- 
мное или аппаратное упущение 
или недоработка, позволяющая 
обойти процессы управления 
доступом. Синонимами являют- 
ся термины ГаиІІ, Па*. 

Мапбаіогу ассезз сопігоі — полно- 
мочное управление досту- 
пом — ограничение доступа к 
определенным объектам, уста- 
новленное на основании выяв- 
ленной степени критичности 
информации, содержащейся в 
данном объекте. При этом обес- 
печивается “прозрачность" дан- 
ного объекта для всех неавтори- 
зованных лиц, т.е. объект как 
бы невидим для них. Управле- 
ние является полномочным, по- 
скольку субъект с конкретными 
правами доступа не может пе- 


редавать эти права другому 
субъекту. 

ОЬ]есі — объект — сущность (т.е. за- 
пись, страница памяти, про- 
грамма, принтер и т.д.), содер- 
жащая или получающая ин- 
формацию. Если субъект имеет 
доступ к объекту, он (субъект) 
исходит из того, что объект 
предоставит ему доступ к хра- 
нимой им информации. 

ОЬіесІ ргоіесііоп — защита объек- 
тов — средства защиты объек- 
тов типа сейфов, файлов и 
т.д. — того, что может быть 
выведено из защищенной об- 
ласти (ргоіесіегі агеа) . 

ОЬ)есІ геизе — повторное использова- 
ние объекта — предоставление 
некоторому субъекту доступа к 
магнитной среде, содержащей 
один и более объектов. Будучи 
доступной для субъекта, маг- 
нитная среда может в то же 
время содержать остатки дан- 
ных от объекта, содержавшего- 
ся на этом месте ранее. 

ОМВА-123 — директива федерального 
правительства, определяющая, 
что при выполнении любыми 
правительственными органами 
или любыми компаниями работ 
для правительства с использо- 
ванием компьютеров подрядчи- 
ки должны составить краткий 
план идентификации и защиты 
ресурсов их информационной 
системы. 

Орегаііопаі баіа зесигііу — операци- 
онная безопасность данных — 
защита данных от модифика- 
ции, разрушения или разгла- 
шения (случайных, неавторизо- 
ванных, либо преднамеренных) 
во время выполнения операций 
ввода, обработки или вывода. 

Огап$е Ьоок — “оранжевая книга* 4 — 
полное название “Берагішепі о( 
Бе^епсе Тгизіеб Сотриіег 
Зузіет Еѵаіиаііоп Сгііегіа" БОБ 
5200.28-ЗТБ (“Критерий оце- 
нивания безопасности компью- 
терных систем министерства 
обороны") — государственный 
стандарт оценивания безопас- 
ности компьютерных систем, 
устанавливающий четыре иера- 
рхических класса — А, В, С и 
Б — определенных уровней до- 
веренности (иными словами, 
уверенности в безопасности) 
для конкретных приложений, 
разрабатываемых и используе- 
мых в интересах правительства. 


3 Зак. 2503 
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3.1 Триединая задача защиты системы 

Чтобы не допустить работы с системой какого-либо 
постороннего лица, случайно оказавшегося за терми- 
налом, необходимо обеспечить распознавание систе- 
мой каждого законного пользователя (или, по крайней 
мере, ограниченных групп пользователей). Для этого в 
некотором (желательно, защищенном) месте системы 
обычно заводится файл, куда записывается ряд при- 
знаков каждого пользователя, по которым можно этого 
пользователя опознать. В дальнейшем при входе в си- 
стему, а при необходимости — и при выполнении 
определенных действий пользователь обязан себя 
идентифицировать. 

Идентификация пользователя заключается в том, 
что он при выполнении каких-либо действий должен 
себя назвать, вернее указать идентификатор, присво- 
енный данному пользователю в данной системе. 

Получив идентификатор, система сравнивает его 
значение с эталоном, который хранится в указанном 
выше файле, и, в случае совпадения, обеспечивает 
возможность пользователю работать с компонентами 
системы. 

Следует отметить, что идентификация не обяза- 
тельно состоит во вводе некоторого имени с клави- 
атуры. Для идентификации пользователя могут при- 
меняться (и успешно применяются!) специальные 
устройства, способные идентифицировать 

пользователя по некоторым его физическим 
характеристикам, например по отпечаткам пальцев, 
спектральному составу голоса или даже по сетчатке 
глаза. Кроме того, для идентификации применяются 
различного рода магнитные карточки, специальные 
ключи и т.д. 

После идентификации система обязательно произ- 
водит аутентификацию полученного идентификатора: 
проверяется содержательность указанного идентифи- 
катора для данной системы. В самом деле, требование 
идентификации заключается только во вводе иденти- 
фикатора. А если пользователь в ответ на запрос вве- 
дет какое-нибудь случайное слово, первым пришедшее 
на ум? Если бы идентификация не дополнялась аутен- 
тификацией, то сама идентификация теряла бы вся- 
кий смысл. Часто аутентификация пользователя осно- 
вана либо на запросе ввода пользователем пароля, 
либо на запросе ответов на некоторые тестовые 
вопросы. В любом случае для проведения 
аутентификации пользователь должен выполнить 
некоторые явные действия. Следует отметить, что 
механизмы, используемые для выполнения ау- 
тентификации, должны быть устойчивы к подлогу, 
подбору или подделке. 

После распознавания пользователя современная си- 
стема должна выяснить, какие права предоставлены 
этому пользователю: какие данные он может исполь- 
зовать (читать, писать, модифицировать, удалять); ка- 
кие программы он может выполнять; когда, как долго 
и с каких терминалов он может работать (да, даже 
это!) и другие вопросы подобного рода. Выяснение си- 


стемой всех этих вопросов называется “авторизацией" 
пользователя***. 

Таким образом, выражение “пользователь авторизо- 
ван для выполнения некоторых действий" означает 
только то, что пользователь имеет право (т.е. ему раз- 
решено ответственными лицами компьютерной си- 
стемы) выполнять в системе эти действия. 

Авторизация обязательно прбводится при входе 
пользователя в систему (т.е. в самом начале работы 
пользователя с системой). Собственно вход в систему 
практически полностью и состоит в выполнении иден- 
тификации, аутентификации и авторизации. 

Однако в процессе последующей работы пользова- 
теля с системой обычно требуется возможность допол- 
нительной авторизации пользователя в отношении ра- 
боты с конкретными ресурсами или выполнения кон- 
кретных действий. 

В настоящее время существуют самые разные меха- 
низмы реализации разделения доступа. 

Одним из таких механизмов являются так называ- 
емые “списки управления доступом". Смысл их со- 
стоит в том, что каждому ресурсу системы при необ- 
ходимости может быть ^сопоставлен некоторым 
образом организованный список, в котором указаны 
идентификаторы всех пользователей, которым 
разрешен (или, наоборот, запрещен) доступ к данному 
ресурсу, а также определено, какой именно доступ 
разрешен. При обращении некоторого пользователя к 
данному ресурсу система автоматически проверяет 
наличие у данного ресурса списка управления 
доступом и, если он есть, проверяет, разрешено ли 
данному пользователю работать с данным ресурсом в 
запрошенном режиме. 

В качестве ресурсов могут выступать как отдельные 
объекты системы (файлы, устройства, носители, про- 
граммы и т.д.), так и целые компоненты системы (все 
данные, все устройства или все программы) и даже 
вся система в целом. 

Другим примером реализации механизма авториза- 
ции пользователя могут служить профили пользовате- 
лей. Профиль пользователя — это тоже организован- 
ный некоторым образом список, сопоставленный опре- 
деленному идентификатору пользователя и содержа- 
щий перечень всех объектов, к которым данному поль- 
зователю разрешен доступ, с указанием в каждом слу- 
чае типа разрешенного доступа. 

Существует также механизм, называемый 
“матрицей доступа". Матрица доступа — это некото- 
рая системная структура данных, которую легче всего 
представить в виде таблицы, столбцы которой поме- 


*** Здесь возможна некоторая путаница. Дело в том, что 
процесс проверки прав пользователя по доступу к системе 
называется авторизацией, но и вся совокупность прав 
пользователя также называется авторизацией. Более того, 
иногда под термином авторизация понимается вообще вся 
совокупность “идентификация/аутентификация/авториза- 
ция 44 . 

Конкретный смысл этого термина определяется обычно по 
контексту, в котором этот термин употреблен. 
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чены идентификаторами всех существующих в си- 
стеме ресурсов, а строки — идентификаторами всех 
зарегистрированных в системе пользователей На пе- 
ресечении каждого столбца таблицы с каждой ее стро- 
кой администратором проставляется специальный ука- 
затель разрешенного данному пользователю типа до- 
ступа к данному объекту. 

Общим для перечисленных, а также для ряда дру- 
гих механизмов, обеспечивающих проведение систе- 
мой в нужный момент авторизации пользователя, яв- 
ляется следующее. Во-первых, доступ к данным меха- 
низмам должны иметь только специальные системные 
программы, обеспечивающие безопасность, а также 
строго ограниченный круг персонала системы, отвеча- 
ющего за ее безопасность. Во-вторых, указанные ме- 
ханизмы сами должны быть тщательно защищены от 
случайного или преднамеренного доступа к ним лиц 
или программ, неавторизованных для этого, поскольку 
эти механизмы (данные и обслуживающие их специ- 
альные программы) являются одной из важнейших со- 
ставляющих в обеспечении безопасности системы. 

Многие известные атаки на системы нацелены на 
поражение или обход именно средств разделения до- 
ступа, поскольку они составляют одно из самых су- 
щественных препятствий на пути любого захватчика. 

3.2 Общесистемные экспозиции 

Помимо того, что сами системные программы могут 
быть нашпигованы самыми различными видами элек- 
тронных ловушек, описанных выше, существует целый 
ряд методов проведения атак на безопасность системы 
в целом с целью получения доступа к отдельным ее 
компонентам. Приведем примеры таких методов: 

1. ВЕТ\ѴЕЕЫ ЫЫЕ8 (между строк) — подключение 
к линиям связи и внедрение в компьютерную систему 
с использованием промежутков в действиях законного 
пользователя. Дело в том, что при интерактивной ра- 
боте терминал большую часть времени простаивает: 
пока пользователь обдумывает что-либо, набирает ко- 
манду, читает выведенную информацию и т.д. Эти 
“окна" вполне могут быть использованы для работы с 
системой кого-либо под маской пользователя. 

2. ТКАРРІС АЫАЕУБІЗ (анализ трафика) — за-^ 
хватчик анализирует частоту и методы контактов 
пользователей в системе. При этом вполне можно вы- 
яснить правила вступления в связь, после чего произ- 
водится попытка вступить в контакт под видом закон- 
ного пользователя. 

3. ЫЫЕ ОІ5СОЫЫЕСТ (разрыв линии) — пользо- 
ватель выходит из системы, либо захватчик разрывает 
линию, но система об этом не догадывается и продол- 
жает работу с захватчиком как с законным пользова- 
телем. 

4. МА5С2ІІЕКАОЕ (маскарад) — захватчик исполь- 
зует для входа в систему ставшую ему известной иден- 
тификацию законного пользователя. 

5. РІССУВАСК (свинство, или “подкладывание 
свиньи") — захватчик подключается к линии связи и 


имитирует работу системы с целью получения инфор- 
мации об идентификации пользователя. Например, он 
может имитировать зависание системы и процедуру 
повторного входа в нее. Пользователь, не подозревая 
об этом, вводит свою идентификацию и пароль, после 
чего захватчик просто возвращает ему управление 
нормально работающей системой. 

Особо следует остановиться на такой не слишком 
известной пользователям экспозиции системы, как 
"повторное использование объектов". 

Чтобы понять смысл этой опасности, следует вспо- 
мнить, что когда, например, операционная система 
сообщает вам о том, что по вашему желанию некото- 
рый файл удален, то это вовсе не означает, что со- 
державшаяся в данном файле информация уничто- 
жена в прямом смысле слова. Удаление файла озна- 
чает только то, что система пометила блоки памяти, 
ранее составлявшие содержимое файла, специальным 
флажком, говорящим о том, что данный блок не вхо- 
дит в состав какого-либо файла и может быть поэтому 
использован для размещения в нем какой-то инфор- 
мации. Но та информация, которая была записана в 
данном блоке раньше, никуда не исчезает! То есть, 
если прочитать сам блок (а это вполне можно сде- 
лать), то можно беспрепятственно получить доступ к 
"удаленной" информации! 

Описанная стратегия “удаления" по ряду вполне 
объективных причин используется в подавляющем 
большинстве компьютерных систем. Причем в каче- 
стве объекта атаки могут фигурировать не только 
блоки файлов, но и различного рода буферы, кадры 
страниц памяти, секторы магнитных дисков, зоны 
магнитных лент, регистры памяти и т.д. 

Вполне логичным представляется то, что описанная 
выше стратегия удаления (а вернее всего — сохране- 
ния, как это ни парадоксально звучит!) провоцирует 
различного рода захватчиков на попытки считывания 
остатков информации прямо из памяти машины. Для 
этого в ряде случаев бывает достаточно создать не- 
большую программку, запрашивающую во время вы- 
полнения динамического выделения дополнительной 
памяти достаточно большого объема. Затем в резуль- 
тате умышленной ошибки эта программа может ава- 
рийно завершаться с выдачей так называемого 
“посмертного" дампа, представляющего собой длин- 
ную распечатку в шестнадцатиричном представлении 
содержимого всех областей памяти, используемых 
“свалившейся" программой. Читать такую распечатку, 
тем более искать в ней что-либо без специальных на- 
выков сложно, поэтому рядовой оператор может и не 
понять, что буквально на его глазах осуществляется 
кража информации. 

Весь смысл такой программки состоит в том, чтобы 
захватить в свое распоряжение как можно больше 
областей памяти, только что использованных про- 
граммой, обрабатывавшей критичную информацию, в 
надежде извлечь из них остатки этой критичной 
информации. Конечно, вероятность выделения про- 
грамме-захватчику именно тех областей, которые со- 
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держат остатки интересующей захватчика информа- 
ции, достаточно мала. Однако такая вероятность су- 
ществует, особенно если программу-захватчика запу- 
стить сразу же по завершении работы программы, 
обрабатывавшей критичную информацию. 

В конце концов, получить дамп интересующих 
областей памяти можно и с использованием ряда 
стандартных системных утилит — и это лишний раз 
доказывает необходимость ограничения доступа поль- 
зователей даже к обычным средствам системы. 

Борьба против атак такого рода заключается в 
устранении возможности считать остатки информа- 
ции. Делается это либо полным затиранием остатков 
информации или заполнением их какой-либо бес- 
смыслицей (в простейшем случае — просто блоком 
сплошных нулей или единиц), либо — более тонко — 
путем отказа любому пользователю в возможности 
прочитать “свободный 14 блок до тех пор, пока этот 
пользователь полностью не заполнил его своей соб- 
ственной информацией. 

В настоящее время ряд операционных систем изна- 
чально содержат встроенные средства блокировки 
“повторного использования 44 . Для других типов опера- 
ционных систем существует достаточно много коммер- 
ческих программ, не говоря уже о специальных паке- 
тах безопасности, реализующих аналогичные фун- 
кции. 

3.3 Четыре базовых средства 
обеспечения безопасности 

Существуют четыре универсальных метода защиты 
и противодействия нарушениям безопасности компью- 
терных систем. 

Первый метод — шифрование данных. Шифрова- 
нием называется некоторое обратимое однозначное 
преобразование данных, делающее их непонятными 
для неавторизованных лиц. Шифрование насчитывает 
тысячелетнюю историю, во всяком случае имеются 
сведения, что к шифрованию донесений прибегали 
еще древнегреческие полководцы. Чтобы получить на- 
глядный пример шифрования, советую вам прочитать 
рассказ Конан Дойля “Пляшущие человечки 44 о Шер- 
локе Холмсе или роман Жюля Верна “Граф Матиас 
Шандор 44 . Помимо названных произведений суще- 
ствует также масса специальной литературы по дан- 
ному вопросу. 

Специалисты считают, что шифрование является 
одним из самых надежных средств обеспечения безо- 
пасности данных. В самом деле, охота за данными в 
компьютерных системах во многом обусловлена тем, 
что слишком многие люди, не имеющие сколь-нибудь 
специального образования, способны разобраться, как 
использовать эти данные в своих личных интересах. 
Но(!) все это имеет смысл лишь при условии, что 
сами данные представлены в понятном виде, например 
в виде строки текста на некотором естественном 
языке. Однако стоит произвести несложную манипу- 
ляцию — провести однозначную замену одних симво- 


лов (допустим, букв) на другие символы (допустим, 
цифры в сочетании со специальными символами) как 
чтение той же строки текста будет весьма серьезно за- 
труднено. 

Метод защиты информации шифрованием подразу- 
мевает обязательное выполнение следующих требова- 
ний. Никто, кроме хозяина данных и лиц, которым 
разрешен доступ к этим данным, не должен знать, 
во-первых, самого алгоритма преобразования данных, 
а, во-вторых, управляющих данных для такого алго- 
ритма — так называемых ключей. 

Доступ к зашифрованным данным обязательно 
включает этап расшифровки данных — т.е. выполне- 
ния обратного преобразования данных из непонятного 
в понятное представление. 

Шифрование делает почти бессмысленным простой 
доступ к данным: ведь, не зная ключа, захватчик мо- 
жет годами биться над украденной абракадаброй, но 
так и не понять смысла данных. Кроме того, шифро- 
вание имеет еще одно немаловажное в смысле безо- 
пасности свойство. Расшифровка возможна только в 
том случае, когда зашифрованные данные не были 
искажены. Искажение зашифрованных данных в сиду 
однозначности преобразования неминуемо повлечет 
искажение данных, получаемых в результате расшифт 
ровки. Таким образом, если захватчик как-либо иска- 
зил (модифицировал) зашифрованные данные, то 
факт нарушения безопасности будет выявлен при пер- 
вой же попытке расшифровки, поскольку в расшифро- 
ванных данных появятся искаженные участки. 

Это свойство особенно полезно для предотвращения 
искажений программ. Код программы шифруется с 
тем, чтобы быть расшифрованным только на время 
выполнения программы. Если в промежутке между 
выполнениями программы .ее зашифрованный код 
исказить, то после расшифровки программа в 
большинстве случаев работать не будет. Хотя и есть 
некоторая вероятность случайного искажения 
зашифрованного кода таким образом, что программа 
все же будет работать, однако вероятность эта очень 
мала. Еще меньше вероятность успешного выполнения 
целенаправленного изменения зашифрованного кода 
программы, например, с целью вставить в нее одну из 
ловушек. 

В идеале данные в расшифрованном виде должны 
существовать только во время их законной обработки 
владельцем и быть зашифрованными во всех других 
случаях — при хранении, пересылке по линиям связи 
и т.д. Однако такое тотальное шифрование суще- 
ственно снижает эффективность системы, так как ее 
значительные ресурсы отвлекаются на выполнение 
операций шифрования/расшифрования. Приемлемый 
вариант обычно достигается путем определения для 
такого способа защиты ограниченного количества 
данных, требующих наиболее высокого уровня 
защиты. 

Второе универсальное средство защиты — регуляр- 
ное создание резервных копий системы- целиком или 
ее наиболее важных компонентов. 
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Имея в запасе резервную копию и столкнувшись с 
искажением ваших данных или их потерей, вы просто 
извлекаете копию утерянных данных и продолжаете 
нормальную работу. Даже если с момента создания 
резервной копии до момента утери данных прошло 
некоторое время, в течение которого вы вносили в эти 
данные какие-либо изменения, наличие резервной ко- 
пии значительно облегчит вам восстановление данных, 
поскольку проще восстановить внесенные изменения, 
чем заново подготовить все данные -целиком. 

Полезность резервного копирования и его важность 
трудно переоценить. Наличие резервных копий 
(лучше всего — нескольких, хранимых в разных ме- 
стах) обезопасит вас от многих неприятностей. В 
частности, наличие резервной копии системы — уни- 
кальный по универсальности спосіэб борьбы с компью- 
терными вирусами. Многими центрами принято хра- 
нить три последних копии системы по схеме “дед- 
отец-сын“. Кроме того, важным считается установле- 
ние определенной дисциплины и порядка копирова- 
ния. Нарушение этой дисциплины карается не менее 
серьезно, чем любое нарушение безопасности. 

Конечно, создание и хранение резервных копий 
требует определенных затрат ресурсов системы, равно 
как и значительного терпения ответственных за копи- 
рование лиц. Но, во-первых, все затраты с лихвой 
окупаются за счет обеспечения безопасности системы, 
а, во-вторых, в современных системах существует не- 
мало средств, специально предназначенных для созда- 
ния резервных копий и существенно облегчающих вы- 
полнение копирования. 

Третье средство предупреждения неприятностей — 
наличие так называемого следа контроля. Для любого 
захватчика серьезным поводом подумать о целесооб- 
разности атаки служит факт наличия в компьютерной 
системе средств осуществления контроля. Контроль 
системы заключается в выделении, накоплении в еди- 
ном месте (так называемом “следе контроля"), защи- 
щенном хранении и предоставлении по требованию 
авторизованного (для выдачи такого требования) поль- 
зователя специальных данных о различных типах со- 
бытий, происходящих в системе и так или иначе вли- 
яющих на состояние безопасности данной компьютер- 
ной системы. 

След контроля не тождествен контрольному жур- 
налу; контрольный журнал — всего лишь частный вид 
реализации следа контроля. По определению след 
контроля — это совокупность записей, содержащих 
требуемую контрольную информацию, представлен- 
ную в установленном формате. Таким образом, след 
контроля может быть реализован в виде специальной 
области памяти, доступ к которой может быть осу- 
ществлен исключительно средствами подсистемы кон- 
троля, либо в виде отдельного устройства, опять же 
защищенного от незаконного доступа со стороны неав- 
торизованных для этого пользователей. 


Контроль системы преследует в основном две цели. 
Он служит: 

a) для отслеживания текущего состояния безопасности 
в защищаемой системе, своевременного обнаружения 
возможности нарушения безопасности и предупреж- 
дения об этом лиц, отвечающих за безопасность си- 
стемы; 

b) для обеспечения возможности обратной трассировки 
(по данным контроля) происшедшего нарушения 
безопасности с целью обнаружения причин данного 
нарушения и установления степени ответственности 
причастных к нарушению лиц. 

Четвертое средство — использование избыточных 
данных. В некотором смысле резервная копия — част- 
ный случай избыточных данных. Но гіе единственный. 

Например, часто практикуется хранение в некото- 
ром защищенном месте системы так называемых риг- 
натур важных объектов системы. 

Например, для файла в качестве сигнатуры может 
быть использовано сочетание байта защиты файла с 
его именем, длиной и датой последней модификации. 
При каждом обращении к файлу или в случае возник- 
новения подозрений текущие характеристики файла 
сравниваются с эталонными. Расхождение каких-то 
характеристик свидетельствует о возможной модифи- 
кации файла (например, может увеличиться или 
уменьшиться длина файла). 

Другим примером избыточных данных является 
применение контрольных сумм, контроль данных на 
чет-нечет, помехоустойчивое кодирование и т.д. В лю- 
бом случае применение избыточных данных направ- 
лено на предотвращение появления в данных случай- 
ных ошибок и выявление неавторизованных модифи- 
каций. 

И. Моисеенков 
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ИНСТРУМЕНТАЛЬНЫЙ КОМПЛЕКС 

ДЛЯ РАЗРАБОТКИ ПРИЛОЖЕНИЙ С ГРАФИЧЕСКИМ ИНТЕРФЕЙСОМ 

’ТРАФИН-ІІ” 


Если Вы — прикладной программист, занятый разработкой информационных систем на 
ПЭВМ, то ”ГРАФИН-Н” — это инструмент для Вас! 

Инструментальный комплекс ”ГРАФиН-И” придаст выразительность и наглядность Вашим 
приложениям за счет оснащения их графическим интерфейсом. Он поможет Вам в создании 
автоматизированных рабочих мест (АРМЬв), информационно-справочных, обучающих систем 
и т.п., требующих использования графического интерфейса в сочетании с возможностью 
ведения баз данных с графическими типами данных. 

’ТРАФИН-ІІ” — ЭТО: 

- графические типы данных в базе данных приложения (растровые образы, пиктограммы, 
векторные типы — точка; линия, контур, область); 

- графический многооконный (подобный М8 ^іпгіодѵз ѵ. 3.0) интерфейс пользователя 
(графическая интерпретация объектов предметной области в сочетании с пиктографическими 
и текстовыми позиционными меню), включая полную поддержку манипулятора ”мышь”, 
диджитайзера, системы сенсорного ввода ТоисЬВсгееп, лазерных и матричных принтеров. 

”ГРАФИН-ІІ” — это инструмент прикладного программиста, позволяющий ему создать для 
пользователя различные приложения с графическим интерфейсом: 

- информационно-справочные; 

- обучающие ; 

- картографические; • 

- и ор. системы . 

Основой комплекса ” ГРАФИН- II” является Графический Процессор, представленный в виде 
объектной библиотеки, включающей около 100 функций и расширяющей Вашу систему 
программирования: Сііррег (версии 5.01 или Зшшпег’в?) или МісгозоН С (версии не ниже 
5*0). 

Геореляционный Процессор ”ГРАФИН-ІІ” позволяет поддерживать графические типы 
данных, расширяющие стандартный набор типов данных Сііррег, либо другой СУБД. 

Для Сііррег 5.01 ” ГРАФИН- II” включает надстройку, расширяющую язык командами работы 
с Графическим и Геореляционным Процессорами, а также эмуляцию стандартной 
подсистемы ввода/вывода Сііррег в графической среде ”ГРАФИН-Н”. 

В состав комплекса ”ГРАФИН-іі” входят также: 

- Универсальная Драйверная система поддержки многоязычной среды, 

• Редактор Пиктограмм, 

- Генератор Графического Диалога, 

- Библиотека Функций Конструирования Графического Интерфейса, 

- Растровый Графический Редактор, 

- Редактор Шрифтов, 

которые помоіут Вам быстро и удобно включить элементы графического интерфейса в свои 
приложения. Все компоненты комплекса снабжены исчерпывающей, включающей много 
примеров, хорошо структурированной документацией (на русском/ английском языках). 
Поставка содержит также встроенную документацию (гГогіоп Синіе) и комплект 
контрольных примеров с исходными текстами. 

”ГРАФИН-П” понимает формат графического редактора РаіпІЬгизЬ (фирма 2зоН), — Вы 
можете создавать в нем собственные изображения, либо редактировать изображения, 
введенные со сканера/видеокамеры. 

Комплекс работает в среде РС ЕЮ8 (М8 Б08) версии не ниже 2.1 на ПЭВМ ІВМ РС/ХТ, АТ, 
АТ-386, Р8/2 и совместимых. Необходимо наличие графического дисплея и адаптера, 
совместимого с ІВМ ССА/ЕСА/ѴСА/МССА. Эффективно поддерживается манипулятор 
”мышь”, совместимый с МісгозоН Моизе, диджитайзер, а также система сенсорного ввода 
ТоцсЬВсгееп. Для ведения значительных по объему графической информации баз данных 
необходим жесткий диск. Графические образы могут быть введены со сканера/видеокамеры. 
Вы также можете получить твердую копию на матричном/лазерном принтере. 

С использованием комплекса ”ГРАФИН-ІІ” нами разработаны информационно-справочные 
системы ’ТОРОД” ”ЯРМАРКА” и ряд демонстрационных примеров, которые мы готовы Вам 
показать, а также ответить на все Ваши вопросы, если Вы обратитесь по адресу: 

СОВЕТСКО-АМЕРИКАНСКОЕ СОВМЕСТНОЕ ПРЕДПРИЯТИЕ 
” Инновационные Информационные Технологии” (ИНИТ) 

252004, Киев-4, ул . Красноармейская, 236 
Телефон; (044) 224-05-74 Факс: (044) 228-27-97 
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вероятно, трудно найти в нашей 
стране пользователей персонального 
компьютера, которому совершенно не 
известно, что такое РС Тооіз, хотя 
этот популярный программный продукт 
рассчитан на более или менее 
подготовленного пользователя, уже 
чувствующего себя профессионалом. 


РС Тоок 7.0 - 

интегрированный 

профессиональный инструментарий 


Изготовитель пакета РС Тооіз, американская фирма 
Сепігаі Роіпі ЗоМдѵаге, входит в число мировых техно- 
логических лидеров по производству программ. Эта 
фирма только что официально объявила о завершении 
работ над новейшей версией пакета — РС Тооіз 7.0. 
Сепігаі Роіпі 8о11\ѵаге утверждает, что этот новый па- 
кет утилит пока является единственным на рынке ин- 
струментальным средством, идеально подходящим для 
всех пользователей персональных компьютеров, кото- 
рые используют в своих машинах новую версию ЭОЗ 
5.0 или ^іпсіолѵз 3.0. 

Благодаря безусловному успеху предыдущей версии 
РС Тооіз 6.0 не только окрепла всемирная слава 
Сепігаі Роіпі ЗоГідѵаге как фирмы, следующей в ногу с 
прогрессом в информационных высоких технологиях, 
но и существенно возросли прибыли от реализации 
программных средств. По известным данным, опубли- 
кованным в прессе, доходы фирмы Сепігаі Роіпі 
ЗоПдѵаге увеличиваются по меньшей мере на 50% 
ежегодно. Всем известно, что на Западе рынок любых 
продуктов информационной технологии в очень боль- 
шой степени зависит от паблисити, и поэтому он тес- 


но связан с отзывами и оценками на страницах веду- 
щих компьютерных журналов. Тем самым многочис- 
ленные компьютерные журналы давно уже преврати- 
лись в органическую часть рынка программ и 
всевозможного компьютерного “железа**, ибо страницы 
журналов — это и есть грандиозная витрина этого 
рынка. Если новый продукт не будет положительно 
отмечен на страницах компьютерных журналов, 
рассчитывать на успешный маркетинг и продвижение 
этого товара на рынок практически невозможно. 

В 1990 году пакет РС Тооіз 6.0 получил высочай- 
шую оценку экспертов редакции журнала РС Ма^а- 
гіпе, почетный приз журнала ІпГоАѴогІсІ за лучший 
продукт 1990 года под названием “Ргоёисі оГ ТЬе 
Ѵеаг“ , приз журнала РС ЛѴогІсІ “1990 ^огд Сіазз 
А\ѵагд“ и множество других призов, наград и востор- 
женных рецензий, продолжающих появляться на стра- 
ницах почти всех компьютерных периодических изда- 
ний мира. Например, журнал ВѴТЕ только что сооб- 
щил в июльском номере, что пакет РС Тооіз Оеіихе 
6.0 завоевал приз читательских симпатий “1991 
Кеасіег'з СНоісе А\ѵапі“. 
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Расположенный в Мюнхене филиал фирмы Сепігаі 
Роіпі 8о!йѵаге ОеиІзсЫапсі СтЬН любезно предоставил 
нам для ознакомления бета-копию новейшей версии 
РС Тооіз 7.0, чтобы заблаговременно оценить ее и 
проинформировать наших читателей о возможностях 
этой “интегрированной группы утилит", как называют 
этот пакет сами изготовители. Исследование бета-вер- 
сии РС Тооіз 7.0 осуществили сотрудники малого 
предприятия "Такт". Знакомство с новой бета-версией 
любой программы, словно генеральная репетиция 
спектакля, обычно не предназначена для публичного 
обсуждения обнаруженных недостатков. Поэтому здесь 
вы сможете узнать только лишь одни хорошие ново- 
сти, характеризующие лучшие стороны нового про- 
граммного продукта, а критические замечания о РС 
Тооіз 7.0 мы сможем высказать позже, проанализиро- 
вав уже готовое изделие. 

Новая версия РС Тооіз 7.0 имеет целый ряд после- 
довательных усовершенствований по сравнению с РС 
Тооіз 6.0. Помимо дюжины новых функций и свыше 
сотни улучшений в работе прежних функций, в этой 
версии предусмотрена возможность работы как под 
управлением 008, так и в графической среде АѴіпбочѵз 

3.0, Выполнение многих функций РС Тооіз 7.0 пре- 
восходно дополняет новую операционную систему 008 

5.0, так как создатели пакета стремились к полнейшей 
программной совместимости и комплиментарности с 
008 5.0. РС Тооіз 7.0 автоматически поддерживает 
новую возможность 008 5.0 размещаться в "верхней 
памяти", освобождая тем самым большую часть 
основной оперативной памяти для размещения при- 
кладных программ. С утилитами РС Тооіз 7.0 совме- 
стима и новая оболочка 008 5.0 8Ье11, используя ко- 
торую вместо оболочки РС8Ье11, входящей в РС Тооіз 

7.0, можно успешно применять многие утилиты РС 
Тооіз 7.0 для восстановления, резервного копирования, 
поиска и просмотра файлов разных форматов. 

Кроме того, РС Тооіз 7.0 имеет развитую поддер- 
жку для работы в локальной сети под Ыоѵеіі ЫеПУаге. 
При работе РС Тооіз 7.0 под П08 на экране 
возникает весьма удобный и визуально очень похожий 
на АѴіпскиѵз графический интерфейс пользователя, 
соответствующий получающему все более широкое 
распространение стандарту ІВМ СИЛ ( Соттоп Іізег 
Ассезз ). Существенно облегчает работу с РС Тооіз 7.0 
и мощная система контекстной гипертекстовой 
справки. Быстро и легко перемещаться внутри этой 
разветвленной Ьеір-системы позволяет гипертекст: 
указав мышью выделенные слова или понятия и лишь 
щелкнув кнопкой, вы мгновенно переходите к более 
глубокой и подробной информации следующего 
уровня. Все команды в РС Тооіз 7.0 можно вводить и 
в командной строке, но едва ли пользователи станут 
пренебрегать эффектной и удобной системой меню. 
Специальная система изменения конфигурации и 
расцветки меню показалась нам даже чрезмерно 
богатой альтернативами. Можно незаметно для себя 
потратить уйму времени, подбирая и экспериментируя 
со всевозможными вариантами оттенков меню, 


надписей и опций. Слишком обширный выбор может 
поставить в тупик пользователя, воспитанного в среде 
нашего извечного дефицита! 

Пожалуй, едва ли можно назвать "хорошей ново- 
стью" то, что новая версия РС Тооіз 7.0 оказалась, 
увы, еще менее компактной, чем предыдущая. Но это 
можно уже признать вполне естественной тенденцией 
в развитии современного программного обеспечения, 
которое явно не желает равняться на бедные техни- 
ческими возможностями персональные компьютеры, 
каких в нашей стране подавляющее большинство. По- 
лученная нами бета-копия РС Тооіз 7.0 занимает 8 
дискет по 720 Кбайт, причем часть программ на этих 
дисках помещена в сжатом виде. При инсталляции 
полного набора утилит РС Тооіз 7.0 для использова- 
ния под Э08 требуется 5,9 Мбайт свободного про- 
странства на жестком диске. Если вы собираетесь 
использовать ее в качестве приложения для Ѵ/іпс1о*з 

3.0, потребуется только 1,9 Мбайт дискового простран- 
ства, помимо около 5 Мбайт, занимаемых АѴіпсіохѵз. 
Кроме того, при работе под 008 необходим минимум 
640 Кбайт памяти, а для использования РС Тооіз 7.0 
вместе с МісгозоН >ѴіпсІо\ѵз 3.0 нужно иметь не менее 
2 Мбайт оперативной памяти. Такие технические тре- 
бования могут кому-то показаться чрезмерно же- 
сткими и отсекающими часть рынка более "слабых" 
персональных компьютеров. Но воспринимать это 
можно и как заявку на рынки сбыта в будущем, когда 
через пару лет возможности средних стандартных пер- 
сональных компьютеров наверняка станут обгонять 
нынешние высшие достижения. 

Приводимый ниже краткий обзор возможностей 
многочисленных утилит, составляющих новую РС 
Тооіз 7.0, показывает, что многие из них существенно 
не изменились в сравнении с предыдущей версией. 
Это вполне соответствует известной концепции марке- 
тинга программных продуктов, которая гласит: 
"торопись медленно", то есть в каждой последующей 
версии программы должна сохраняться логическая 
преемственность с предыдущими версиями. Несо- 
мненно, эта заповедь в РС Тооіз 7.0 свято соблюдена, 
и те пользователи, которым уже знакомы предыдущие 
версии, смогут без труда адаптироваться к переменам 
и новшествам новой версии. 

Резервное копирование жесткого диска 
в Б08 и \Ѵіпс1о\ѵ5 

Утилита Васкир включает полную совместимость 
данных и полную идентичность манипуляций клави- 
шами при использовании приложений под И08 и 
>ѴіпсІо^ѵз. Новый очень выразительный интерфейс 
пользователя внешне очень похож как для 008, так и 
для ЛѴіпсІо^ѵз. 

Резервное копирование может осуществляться в фо- 
новом режиме в процессе работы в приложениях ѴПп- 
бодѵз. Возможно использование автоматического ре- 
жима выполнения резервного копирования по установ- 
ленному графику. Поддерживается широкий перечень 
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различных устройств для резервного копирования на 
гибкие и жесткие диски, на кассеты Бернулли и на 
стримеры формата (^ІС-40/80 и Іпѵіп. Допустимо ре- 
зервное копирование записей длиной до 250 Мбайт на 
кассету с магнитной лентой. Скорость передачи дан- 
ных — до 7 Мбайт/мин при записи на магнитную 
ленту и до 3,5 Мбайт/мин при записи на гибкие 
диски или другие устройства 008. При этом данные 
могут сжиматься до 60% для экономии места на носи- 
телях со снижением скорости записи. 

В целях повышения надежности перед записью 
осуществляется верификация носителя резервной ко- 
пии. Возможно побитовое сравнение для выбора теку- 
щих файлов для копирования. Также возможна кор- 
рекция ошибок при извлечении данных с поврежден- 
ных дискет, жестких дисков и магнитных лент. 

Восстановление утраченных данных 

Эта традиционная для РС Тооіз функция предна- 
значена для восстановления данных на диске, утра- 
ченных вами почти по любым возможным 
“сценариям": после уничтожения или повреждения 
файлов, из-за нарушений в работе жестких дисков и 
даже из-за нечаянного форматирования дисков. Че- 
тыре различные утилиты выполняют эту важную фун- 
кцию. 

Утилита ОізкПх консультирует пользователя о со- 
стоянии и использовании дисков, объясняет, как сле- 
дует понимать сообщения 008 об ошибках, произво- 
дит автоматическую диагностику гибких и жестких 
дисков, а также их последующее “лечение". Причем 
команда “Ііпсіо" все изменения позволяет опять при- 
вести в прежнее состояние. Могут подвергаться 
“лечению" любые диски с нарушенной таблицей раз- 
биения ( РагШіоп ) диска, с поврежденной загрузоч- 
ным ( Воо! ) сектором, с потерянными кластерами, с 
поврежденной таблицей расположения файлов (РАТ), 
разрушенным корневым каталогом и подкаталогами 
или с файлами, которые “переплелись" друг с другом. 

Утилита РіІеРіх позволяет восстанавливать повреж- 
денные файлы форматов 6ВАЗЕ, Ьоіиз 1-2-3 (в том 
числе и версии 3.x) и 8уш1опу. 

Превосходная утилита ІІпсіеІеІе восстанавливает 
уничтоженные файлы как в отдельном компьютере, 
так и в локальной сети. Эта утилита также работает 
под 008 и \Ѵішкжз. При использовании для уничто- 
жения файлов утилиты Зепігу, не позволяющей 
использовать для перезаписи освободившееся про- 
странство на диске, практически всегда возможно 
полное восстановление уничтоженных данных, даже в 
сети. 

Уничтоженные файлы сортируются по дате, вре- 
мени и состоянию. Даже если уничтожен подкаталог, 
возможно восстановление файлов, баз данных и элек- 
тронных таблиц. Кроме того, возможно детальное вос- 
становление сильно поврежденных файлов вручную. С 
помощью этой утилиты возможно восстановление 
файлов, разорванных на отдельные фрагменты, на- 


пример, после неудачной “оптимизации" диска, после 
переписывания или перемещения имен каталогов, ча- 
стично — после перезаписи файлов или после случай- 
ного форматирования диска. 

Утилита ІІпГогтаІ “ремонтирует" жесткий диск: 
вновь воссоздает утраченную таблицу РАТ по ее 
“отраженному" образу в специальном защищенном 
файле Міггог, который всегда находясь в корневом ка- 
талоге на диске, сохраняет и регулярно обновляет 
информацию, необходимую для восстановления таб- 
лицы расположения файлов. При этом после 
“деформатирования" диска гарантируется 100%-ное 
восстановление утраченных данных, если диск был 
отформатирован специальной утилитой РС Тооіз 7.0. 

Защита данных и дисков 

С помощью нескольких утилит ваши ценные дан- 
ные могут быть надежно защищены от потерь из-за 
случайного форматирования диска, заражения виру- 
сами, нарушений в работе носителей или потери па- 
мяти СМ08. 

В РС Тооіз 7.0 имеется весьма полезная утилита 
для безопасного освежения адресов дисковых секторов, 
которые записываются только однажды при формати- 
ровании и обычно со временем стареют и размагничи- 
ваются. Рано или поздно это приводит к потере дан- 
ных или даже к полному “крушению" жесткого диска, 
когда вдруг ваш компьютер начинает выдавать непри- 
ятные сообщения типа “8ес!ог по! Іоипд" или “8еек 
еггог". Эта утилита РС Тооіз 7.0 тщательно сканирует 
всю поверхность диска, производя испытания на чте- 
ние/запись по 80 параметрам, чтобы обнаружить и 
отбраковать вновь возникающие ненадежные секторы. 
Затем корректируется фрагментация файлов на диске 
и настраивается фактор чередования сегментов для 
оптимизации скорости работы жесткого диска. 

Специальная резидентная программа, занимающая 
20 Кбайт в ОЗУ, способна, как утверждает фирма 
Сепігаі Роіп ЗоНчѵаге, распознать свыше 600 вирусов в 
любом файле, каталоге, в памяти или в загрузочном 
секторе. При диагностировании вируса после его по- 
ступления в компьютер по сети или с дискетами, она 
немедленно отключает жесткий диск, дает сообщения 
новых версий вирусов. Служба поддержки Сепігаі 
Роіп! 8о!йѵаге обязуется регулярно снабжать зареги- 
стрированных пользователей обновленными версиями 
этой утилиты. 

Таблица расположения файлов на диске (РАТ), за- 
грузочный (Вооі) сектор и корневой каталог любого 
диска могут сохраняться в специальном защищенном 
файле, создаваемом утилитой Міггог, на тот случай, 
если понадобится быстро и надежно восстановить диск 
после неожиданного аварийного отключения питания 
или после случайного форматирования диска. 

Специальная загрузочная дискета, создаваемая РС 
Тооіз 7.0, позволяет перезагрузить компьютер после 
любой неисправности, так как на ней имеются все не- 
обходимые для восстановления файлы, включая загру- 


4 Зак. 2503 
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зочный сектор, таблицу разбиения диска и образ 
СМОЗ-памяти. 

Сервисная система БеШор 

С помощью системы Безкіор можно легко и удобно 
организовать групповое использование персонального 
компьютера, вести всевозможные записи в записной 
книжке и в простой базе данных, пользоваться кален- 
дарем и калькулятором, составлять списки “что сде- 
лать“, а также получать в установленный срок напо- 
минания, скажем, о назначенной встрече или о сове- 
щании с коллегами в локальной сети. Эта же система 
позволяет производить регулярное резервное копи- 
рование данных, автоматически отправлять в удобное 
время факсимильные сообщения и электронную 
почту. 

База данных системы Оезкіор совместима с фай- 
лами формата СІВА5Е, что позволяет легко пользо- 
ваться имеющимися файлами, создавать и редактиро- 
вать новые файлы, составлять списки и отчеты, 
“сливать 4 * тексты стандартных писем с адресами и 
осуществлять автоматический набор телефонных но- 
меров через модем. 

В простом текстовом процессоре, встроенном в 
Эезкіор, можно легко создавать любые по объему до- 
кументы. В нем имеется функция Маіі-тег^е, позво- 
ляющая “сливать 44 тексты писем с адресами из базы 
данных. На экран могут выводиться одновременно до 
15 “листков 44 из электронной записной книжки. В тек- 
стовом процессоре имеются практически все важней- 
шие функции специализированных программ такого 
типа: автоматическая проверка правописания английс- 
кого языка, поиск и замена фрагментов текста, пере- 
мещение фрагментов текста, форматирование стра- 
ницы перед печатью. 

В РС Тооіз 7.0 имеется сразу 4 встроенных кальку- 
лятора — обычный алгебраический и специальные для 
научных и финансовых расчетов, а также для про- 
граммистов. Автоматически через модем могут наби- 
раться номера любых телефонов, либо вводимых в ко- 
мандной строке, либо сохраняемых в системе Оезкіор 
или в любой другой прикладной программе. Трудно 
кратко перечислить все возможности, представляемые 
в системе Эезкіор. Вот для примера еще несколько. 

С помощью утилиты СНрЬоагб в системе Оезкіор 
можно “вырезать 44 любые данные, отображаемые на 
экране, и вставлять их в различные приложения. Ути- 
лита Магсо е<Шог позволяет системе запоминать лю- 
бые длинные комбинации клавиш, которыми вам при- 
ходится часто пользоваться, а затем воспроизводить 
всю эту макрокоманду после нажатия лишь одной 
условной клавиши. А чрезвычайно полезная утилита 
ОиШпег предназначена для составления планов и рас- 
писаний, оглавлений и списков важных мероприятий, 
встреч, покупок и тому подобных дел и событий, из 
которых состоит жизнь любого занятого человека, для 
разработки и обдумывания структуры различных до- 
кументов, докладов, речей, романов. 


Управление дисками и файлами 

Утилиты РіІеРіпсі и Ѵіе^ позволяют весьма удобно 
и оперативно находить по любым признакам (а в тек- 
стовых файлах даже по образцу фрагмента текста!) и 
просматривать файлы данных различного формата из 
более чем 35 распространенных прикладных 
программ: из практически всех наиболее популярных 
текстовых процессоров, электронных таблиц, систем 
управления базами данных, а также просматривать 
графические файлы формата РСХ из программы РС 
РаіпіЬгизН и из архивов форматов АЯС, Ь2Н, РАК, 
РК2ІР и 200. 

Оболочка Э05, предлагаемая в РС Тооіз 7.0, на 
наш взгляд, более удобна и гораздо богаче возможно- 
стями, чем, скажем, известная оболочка Ыогіоп Сош- 
тапсіег или ЭОЗ ЗЬеІІ версии 4.01. Впрочем, по- 
скольку “на вкус и цвет товарищей нет 44 , выбор под- 
ходящей оболочки остается делом весьма индивиду- 
альным: последнее слово в окончательном выборе 
всегда должно оставаться за пользователем. Доста- 
точно назвать несколько отличительных особенностей 
имеющейся оболочки 005: просмотр содержимого 
двух файлов одновременно, копирование файлов на 
несколько дисков, возможность резидентного располо- 
жения в памяти (оболочка занимает при этом всего 10 
Кбайт), переназначение функциональных клавиш по 
вашему вкусу и многое другое. 

Помимо перечисленных возможностей, оболочка РС 
Тооіз 7.0 позволяет защищать имеющиеся прикладные 
программы от нежелательного доступа посторонних 
лиц секретным паролем. Замечательно, на наш взгляд, 
выглядит и графическое представление объема катало- 
гов (точнее, того, сколько места они занимают на 
диске) при просмотре дерева каталогов на экране. 

Системная и сетевая информация 

РС Тооіз 7.0 производит всестороннее тестирование 
системы утилитой 51 и сообщает пользователю более 
чем о 160 параметрах, исчерпывающе характеризу- 
ющих используемую компьютерную систему и под- 
ключенную коммуникационную сеть. 

Помимо многочисленных полезных данных о типе 
используемого процессора и его производительности, о 
версии операционной системы, о прерываниях, о типе 
видеоадаптера, о различных текстовых параметрах 
скорости чтения/записи дисководов и другой 
внутренней статистике, на экране графически 
отображается информация о распределении памяти. 
Детально сообщается об используемых физических и 
логических дисках (включая сетевые) и о виртуальных 
ЯАМ-дисках. 

Утилита 51 подробно сообщает также о всех 
сетевых параметрах, о версии и изготовителе сетевого 
программного обеспечения, дает детальный и 
обобщенный отчет о каждом сетевом сервере, 
составляет списки серверов, список пользователей по 
каждому серверу, а также выводит всевозможную 


КомпьютерПресс 1Г91 




ПРОГРАММНОЕ ОБЕСПЕЧЕНИЕ 


27 


информацию о группах пользователей и о простран- 
стве сервера для каждого клиента. 

Графически в виде гистограмм отображаются ре- 
зультаты теста ВепсНшагк — сравнительная скорость 
работы процессора и дисков, обобщенная производи- 
тельность системы, а также график производительнос- 
ти сети по времени чтения/записи на сервер. Кроме 
того, не выходя из РС Тооіз, можно просматривать 
файлы АІГГОЕХЕС.ВАТ и ССЖРІС.5Ѵ8, а также по- 
лучить другие данные о конфигурации системы. 

Использование компьютера на расстоянии 

Система связи Соттиіе пакета РС Тооіз 7.0 позво- 
ляет с помощью, например, домашнего персонального 
компьютера или переносного Іаріор-компьютера за- 
пускать прикладные программы, работающие под 
управлением ООЗ и Ѵ^іпскдѵз в компьютерах или в ло- 
кальной сети где-то на удалении, скажем, на вашем 
предприятии или в учреждении. Передача информа- 
ции по кабелю, по телефонной линии через модем 
или в локальной сети ускоряется вдвое, благодаря 
компрессии данных. Можно распечатывать файлы, 
управлять приложениями >Ѵіпс1одѵз и пользоваться 
мышью либо на собственном, либо на удаленном 
компьютере. Система Сошшиіе функционально 
совместима с сетями типа Ыоѵеіі (версия 2.15 и выше) 
и позволяет получать и передавать электронную почту 
и получить доступ к любому персональному 
компьютеру сети через модем. 

Ваш компьютер может быть защищен от нежела- 
тельного доступа секретным паролем, автоматически 
отзываясь и требуя подтверждения права доступа. 
Причем защита от несанкционированного доступа мо- 
жет быть многоуровневой, а вся запрашиваемая 
информация регистрируется. Эта система Соппшііе 
имеет множество других дополнительных полезных 
сервисных удобств, предназначенных для существен- 
ного облегчения работы в локальной сети. 

Оптимизация технических 
характеристик системы 

Помимо уже упоминавшихся утилит, позволяющих 
диагностировать и максимально оптимизировать ско- 
рость работы жесткого диска, благодаря дефрагмента- 
ции и реорганизации расположения файлов на диске, 
а также благодаря оптимальной настройке фактора 
чередования в последовательности расположения сек- 
торов в каждом из цилиндров жесткого диска, в РС 
Тооіз 7.0 имеется дополнительная возможность уско- 
рить операции чтения/записи жесткого диска, за счет 
сохранения наиболее часто используемых данных в 
кэш-памяти. 

Утилита Бізк СасЬе также работает под ^іпсіоаѵб и 
позволяет использовать расширенную и дополнитель- 
ную (ЕМЗ) память компьютера. В кэш-памяти однов- 
ременно могут сохраняться данные, относящиеся сразу 
к четырем жестким дискам. 


Телекоммуникация 

С помощью встроенных утилит коммуникации, вхо- 
дящих в РС Тооіз 7.0, ваш компьютер может быть 
присоединен к другим компьютерам как внутри ва- 
шего предприятия или учреждения, так и к любому 
персональному компьютеру в любом конце света, 
используя связь по телефонным линиям через модем, 
факс-плату или подключение к службам электрон- 
ной почты типа МСІ шаіі, СотриЗегѵе или Еазу- 
Ііпк. 

Процесс передачи и получения электронной почты 
максимально автоматизирован. Поддерживается эму- 
ляция терминалов АЫ5І, ѴТ100 и ѴТ52. Через модем 
можно передавать файлы, используя протоколы 
ХМСШЕМ или А$ІІ. Факсимильные сообщения можно 
посылать и получать как на обычный аппарат факс, 
так и на другой персональный компьютер, снабжен- 
ный встроенной факс-платой в разъеме расширения. 

Безопасность хранения данных 

Учитывая ценность информации, которая может 
храниться в персональных компьютерах, богатый вы- 
бор разнообразных мер обеспечения безопасности и 
секретности, предлагаемых пакетом РС Тооіз 7.0, по- 
жалуй, никак нельзя считать излишним. 

Любая конфиденциальная информация, содержаща- 
яся в ваших файлах и каталогах, находящихся на дис- 
ках и передаваемых в сетях, может включать автома- 
тическую шифровку по вашему собственному секрет- 
ному паролю. 

Кроме того, предусмотрена защита указанных поль- 
зователем файлов, каталогов и системных областей 
или всего диска от случайной перезаписи. Экран мо- 
нитора, содержащий конфиденциальную информацию, 
может не только очищаться (и тем самым продлевать 
срок службы монитора), но и имеет встроенную за- 
щиту по паролю, чтобы в ваше отсутствие ограничить 
нежелательный доступ к компьютеру для посторонних 
лиц. И, наконец, имеется традиционная для РС Тооіз 
утилита >Ѵіре, позволяющая бесследно уничтожать не- 
нужные данные в файлах или на всем диске. 

Минимальные требования к системе 

Пакет РС Тооіз 7.0 предназначен для работы на 
персональных компьютерах типа ІВМ РС, ХТ, АТ, 
Р5/2 или на 100% -совместимых машинах, имеющих 
640 Кбайт ОЗУ и ЭОЗ 3.0 или выше. Применение 
БОЗ 5.0 рекомендуется. Приложения ^іпгіотѵз могут 
выполняться, если имеется МісгозоН ^іпсіоіѵз 3.0 или 
выше и 2 Мбайт ОЗУ. В любом случае необходим 
жесткий диск. Поддерживаются драйверы мыши Мі- 
сгозоН Моизе версии 6.14 или выше, а также драйверы 
мыши Ьо^ИесН/Оехха версии 3.4 х или выше либо 
100% -совместимые. Предполагается использование 
модема типа Науез, поддерживается ЫеАѴаге 2.15 или 
выше и Ыеі^аіе 386. 
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РС ТООБЗ 7.0 — ИНТЕГРИРОВАННЫЙ ПРОФЕССИОНАЛЬНЫЙ ИНСТРУМЕНТАРИЙ 


Хотя бета-версии программ обычно не вполне со- 
впадают с готовым продуктом (в конце концов, для 
того они и создаются, чтобы искать в них возможные 
ошибки и недостатки), без риска ошибиться можно 
уже сегодня предположить, что новому пакету РС 
Тооіз 7.0 уготована не менее успешная судьба, чем его 
предшественнику. Преемственность испытанных и уже 
нашедших широкое признание инструментов в РС 
Тооіз 7.0 не только тщательно сохранена, но и 
Существенно обогащена новыми мощными и 
полезными возможностями, хотя в этой статье не- 
возможно было упомянуть и прокомментировать каж- 
дую из них. Но даже некоторые из перечисленных 
возможностей РС Тооіз 7.0 могут сегодня вызвать за- 
висть и огорчения у некоторых читателей или пока- 
заться явно излишними из-за скудных технических 
возможностей отечественного парка компьютеров и се- 
тей коммуникации. Кто-то может даже сказать, что 
“они там с жиру бесятся 44 или пробурчать что-то об 
“элитарности 44 утилит для АѴіпскпѵз. 

Не стоит, однако, забывать, что создается этот па- 
кет отнюдь не по нашей мерке, а прежде всего для за- 
падного рынка. Во-вторых, прогресс все-таки происхо- 
дит и у нас, хотя, быть* может, и не столь стреми- 
тельно, как нам того хотелось бы, а каждый шаг в 
улучшении проклятого “железа 44 'заставляет раскоше- 
ливаться. Однако рано или поздно большинство этих 
возможностей РС Тооіз 7.0 станут полезными и акту- 
альными для многих. Ну и, наконец, в-третьих, про- 
цесс инсталляции позволяет выбирать из обширного 


интегрального инструментария РС Тооіз 7.0 только те 
инструменты, которые вам нужны или могут быть по- 
лезны именно сегодня, и тем самым позволяет сэконо- 
мить используемое дисковое пространство и свободную 
память. Пользователь может даже “дезинтегрировать 44 
эту систему и выбрать из нее лишь несколько самых 
необходимых утилит, которыми можно пользоваться 
даже на самом скромном персональном компьютере. 

Девиз Сепігаі Роіпі ЗоНіѵаге гласит; “Сделаем так, 
чтобы работа на компьютере стала безопаснее, проще, 
быстрее 44 . Несомненно, представленный сегодня интег- 
рированный пакет утилит РС Тооіз 7.0 — это верный 
очередной шаг в указанном стратегическом направле- 
нии. Ну, а каков окажется окончательный вариант 
этой программы, надеюсь, все мы скоро сможем 
узнать. 

Для желающих связаться с мюнхенским филиалом 
Сепігаі РоіпІ 8оНіѵаге, который отвечает за маркетинг 
и поддержку продуктов этой фирмы в ФРГ, Австрии, 
Швейцарии и в странах Восточной Европы, сообщаем 
контактные реквизиты: 

Сепігаі Роіпі 5>оН\ѵаге ОеиІзсЫапсІ СтЬН 
ЬеороІсЫг. 28 а/ІІ 
8000 МипсНеп 40 
ВІШ 

Телефон: (089) 33 67 17 
Факс: (089) 33 57 31 

А.В. Петроченков 
Телефон: (08100) 5 58 05 


сіетоз/* предлагает: Система Автоматизации “ЛабСервис” 

Программно-технический комплекс “ЛабСервис” - это набор стандартных плат для ІВМ РС АТ/ХТ и пакет 
программ для М3 БОЗ. 

Набор плат “ЛабСервис” для ІВМ-совместимых компьютеров: 

Платы АЦП-ЦАП. Платы релейных коммутаторов и цифровых каналов. Платы цифровых каналов (до 24 вх/вых.). Платы интерфейса 
канала общего пользования. Платы ЦАП. Платы аналоговых усилителей. Блок АЦП: 20 разр., связь по К8-232 (изготавливается на заказ) . 
Контроллер крейта КАМАК для ІВМ РС. 

“ЛабСервис” обеспечивает: 

• многоканальный ввод/вывод аналоговых и цифровых сигналов, нормирование аналоговых сигналов, высокую скорость процедур 
сбора данных (до 10 кГц) ; 

• разнообразные алгоритмы сбора данных и управление процессами в реальном масштабе времени; 

• оперативное отображение на экране собираемых данных и управляющих воздействий; 

• сохранение полученных данных в форматах различных пакетов для их последующей обработки (МаіЬЬаЬ, сІВазе, Ргатеѵѵогк и др.) 

• реализацию сложных сценариев процесса, отражающих взаимодействие и синхронизацию процедур сбора данных и управления; 

• ведение архива сценариев и результатов. 

Пакет удобен в использовании и не требует знания программирования - с помощью 
систем меню можно быстро описать требуемые процессы. 

ДЕМОС/*: 1 13035 Москва, Овчинниковская наб. дом 6/ 1 , 
телефон: 231-21-29, 231-63-95; Рах: (095) 233.5016; Е-таі1: іп1о@Ьд.<іето$.5и 
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С момента нажатия клавиши на 
клавиатуре до отображения прикладной 
программой символа на экране 
совершается целая последовательность 
событий. Эта статья начинается с 
обзора прерываний , обслуживающих 
события, связанные с клавиатурой. 
Затем рассматриваются программные и 
аппаратные средства, относящиеся к 
клавиатуре и ее прерываниям; 
непонятная техническая терминология 
попутно поясняется. Далее 
предлагаются примеры программ, 
демонстрирующих внутреннюю работу 
клавиатуры. И, наконец, представлены 
некоторые утилиты, улучшающие 
функциональные возможности 
клавиатуры. Статья перепечатывается 
из журнала Місгоюр Зузіет Іоитаі, ѵ.5, 
Ыо.1, 1990 с любезного разрешения 
фирмы Місгозо р. 


Клавиатура: от Л до 2 


Подробное исследование 
работы клавиатуры ПК 
и обслуживающих ее прерываний 


При работе с любой программой стоит вам только 
нажать на клавишу, как на экране мгновенно появля- 
ется символ. Это позволяет предположить, что между 
монитором и клавиатурой существует непосредствен- 
ная связь. В действительности в процесс, сопровожда- 
ющий нажатие на клавишу, включены мириады со- 
ставных частей. 

Первым шагом на пути к пониманию работы клави- 
атуры становится знакомство с системой 
обслуживания прерываний ПК. Под прерыванием 
понимается временное прекращение центральным 
процессорным устройством (СРП — ЦПУ) текущей 
работы для выполнения некоторых посторонних 
действий, по завершении которых процессор 
возвращается в прежнее состояние и продолжает 
прерванную работу. Каждое прерывание имеет свой 


номер, по которому ЦПУ находит подпрограмму для 
его обработки. Семейство процессоров 80x86 
обеспечивает работу с двумя типами прерываний — 
программными и аппаратными. Аппаратное 
прерывание возникает тогда, когда какое-либо 
устройство нуждается в экстренном обслуживании и, 
как правило, такое прерывание — большая не- 
ожиданность для ЦПУ. 

В отличие от аппаратных, программные прерывания 
инициируются изнутри основной программы при по- 
мощи специальных команд процессора. Программное 
прерывание можно представить так, как будто про- 
грамма прерывает сама себя для выполнения подпро- 
граммы, не являющейся частью ее кода. Обращение к 
программному прерыванию похоже на вызов функции, 
за тем исключением, что нет необходимости написа- 
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ния самой функции. К одной из основных задач опе- 
рационной системы (005 или 03/2) относится обес- 
печение пользователя набором стандартных подпрог- 
рамм обработки прерываний с тем, чтобы отпала не- 
обходимость многократного переписывания наиболее 
общих (и, надо отметить, наиболее неприятных) на- 
боров команд для всех выполняемых прикладных про- 
грамм. 

При нажатии на клавишу электронные схемы кла- 
виатуры генерируют аппаратное прерывание, инфор- 
мирующее ЦПУ о том, что произошло событие, кото- 
рое необходимо немедленно обработать. Экстренность 
обработки обусловлена тем, что клавиатура способна 
запоминать только до 4 нажатий. Если эти нажатия 
не будут переданы процессору, то они потеряются. 
Для предотвращения этого ЦПУ запоминает текущее 
состояние задачи (например, пересчет электронной 
таблицы) и выполняет специальную программу обра- 
ботки сигналов клавиатуры. Эта программа называется 
ШТ 09Н или “обработчик аппаратного прерывания от 
клавиатуры 44 . Так как обработка данных с клавиатуры 
относится к наиболее важным функциям системы, 
программа обработки ШТ 09Н встроена в ПЗУ и яв- 
ляется частью ВІ05. 

Прерывание ІІЧТ 09Н 

Основная функция программы ВІ08 ШТ 09Н — 
получение информации о нажатии на клавишу через 
порт ввода /вы вода А микросхемы 8255-А, обработка 
этой информации и сохранение ее в буфере клави- 
атуры. Буфер клавиатуры — это небольшой участок 
памяти в зарезервированной области ОЗУ, называемой 
областью данных ВІ08. Единственная информация, 
которую программа обслуживания прерываний полу- 
чает от клавиатуры — это число, называемое скан-ко- 
дом и представляющее собой физический номер нажа- 
той или отпущенной клавиши. Большинство приклад- 
ных программ ожидают поступления от клавиатуры 
кода символа (А5СІІ-кода), поэтому каждое нажатие 
на клавишу приходится специальным образом обраба- 
тывать. Например, при нажатии на клавишу “А 44 кла- 
виатурой посылается число (скан-код) 1ЕН. Про- 
грамма ШТ 09 Н определяет по таблице, что это кла- 
виша А. Попутно ШТ 09Н проверяет состояние не- 
символькых клавиш, таких как СарзЬоск и левый или 
правый ЗЫН с тем, чтобы определить, прописная это 
буква или строчная. Затем скан-код и его А5СІІ-ин- 
терпретация запоминаются в буфере клавиатуры и 
программа ШТ 09Н завершается. ЦПУ — или, вер- 
нее, счетчик команд — возвращается на то самое ме- 
сто, в котором его работа была прервана. При этом 
система восстанавливается таким образом, что пре- 
рванная программа и “не подозревает 44 , что была на 
некоторое время “заморожена 44 . 

Если работа ШТ 09Н происходит “совершенно не- 
заметно 44 , то как же осуществляется передача при- 
кладной программе информации о введенных симво- 
лах? Для этого в операционной системе имеется не- 


сколько подпрограмм, объединенных под эгидой обра- 
ботчика программного прерывания ШТ 16Н. 

Прерывание ШТ 16Н 

Если единственная обязанность аппаратного преры- 
вания ШТ 09Н — это прием данных с клавиатуры, их 
интерпретация и занесение в буфер, то программное 
прерывание ШТ 16Н обладает большей гибкостью, 
предоставляя целых 3 подфункции (пронумерованные 
от 0 до 2). Прикладная программа задает необходи- 
мую функцию путем передачи обработчику ШТ 16Н 
номера этой функции в регистре АН перед выполне- 
нием прерывания. 

Первая функция (с номером 0 или ООН) передает 
прикладной программе информацию о нажатой кла- 
више (ее скан- и А5СІІ-коды) из буфера клавиатуры. 
При использовании этой функции надо учитывать 
одну ее особенность. Дело в том, что буфер клави- 
атуры большую часть времени пуст, а прерывание 
ШТ 16Н ООН (т.е. прерывание ШТ 16Н, функция 
ООН) обязано вернуть информацию о нажатой кла- 
више. Поэтому функция ООН заставляет ЦПУ выпол- 
нять цикл ожидания до тех пор, пока в буфере не по- 
явится какой-либо код — т.е. пока не будет нажата 
какая-нибудь клавиша. 

Для того, чтобы понять, каким образом во время 
пребывания процессора в цикле ожидания в буфер по- 
ступает информация, обратимся к прерыванию 
ШТ 09Н. Это аппаратное прерывание вырабатывается 
при любом нажатии на клавишу и, прерывая просмотр 
функцией ШТ 16Н ООН буфера клавиатуры, заносит в 
него данные. После окончания работы прерывания 
ШТ 09Н, функция ШТ 16Н ООН внезапно обнаружи- 
вает поступившие с клавиатуры данные и передает их 
прикладной программе. 

Функция 01 Н прерывания ШТ 16Н в некоторых 
случаях более эффективна. Эта функция позволяет 
программе определить, есть в буфере данные или нет 
и затем немедленно возвращает управление приклад- 
ной программе. Все, что остается программе — это 
периодически обращаться к функции ШТ 16Н 01 Н и 
проверять заполненность буфера. Если будет получен 
ответ “да 44 , то программа сможет немедленно прочи- 
тать символ с помощью функции ШТ 16Н ООН. 

Последняя функция прерывания ШТ 16Н имеет 
номер 2 (02Н) и возвращает текущую информацию о 
клавишах СарзЬоск, Іпзегі, ЫшпЬоск, ЗсгоПЬоск, АН, 
Сігі, левый и правый ЗЫН. Мы вернемся к этой фун- 
кции несколько позднее. 

Таким образом, главное отличие между ШТ 09Н и 
ШТ 16Н состоит в том, что ШТ 09Н является аппа- 
ратным прерыванием, выполняемым В108, и исполь- 
зуется исключительно клавиатурой для сохранения 
данных о нажатых клавишах. ШТ 16Н — это про- 
граммное прерывание, выполняемое ПЗУ ВІ05 и 
используемое прикладными программами по мере не- 
обходимости для получения данных о нажатых клави- 
шах. 
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Подробнее о прерываниях 

Так как концепция прерываний является ключевой 
в понимании функционирования клавиатуры (как 
впрочем и любых других устройств), рассмотрим ра- 
боту прерываний поподробнее. Как для программных, 
так и для аппаратных прерываний семейство процес- 
соров 80x86 выполняет одну и ту же последователь- 
ность операций. В обоих случаях управление временно 
передается программе, называемой обработчиком пре- 
рывания. При возникновении аппаратного прерывания 
переход на его обработчик вызывается воздействием 
сигнала, поступающего на специальный вывод процес- 
сора. Программные же прерывания инициируются са- 
мим процессором при выполнении инструкции ШТ 
(ШТеггирІ — прерывание). У команды ШТ имеется 
обратная команда — ІЯЕТ (Іпіеггирі ЯЕТигп — воз- 
врат из прерывания), используемая обработчиком пре- 
рывания для возврата управления прерванной про- 
грамме. Рассмотрим сначала, что делает ЦПУ при вы- 
полнении команды ШТ. 

При возникновении прерывания, независимо от 
того, инициировано оно извне — аппаратно, или 
изнутри — программой, ЦПУ прежде всего сохраняет 
текущее состояние регистра флагов в стеке. После 
этого очищаются флаг прерываний (ІР) и флаг трас- 
сировки (ТР). Очистка флага ІР (ІпіеггирІ-епаЫе 
Р1а§) делает то же, что и инструкция СЫ (Сіеаг Іпіег- 
гирІ-епаЫе Ріа^ — очистка ІР, запрет прерываний) — 
запрещает прерывания (все, кроме немаскируемых 
прерываний, напр., ШТ 02Н), обеспечивая непрерыв- 
ную работу ЦПУ в течение всего времени выполнения 
процедурой ШТ критичного задания. Обработчик пре- 
рываний должен разрешить прерывания сразу, как 
только это станет возможно, используя команду 8ТІ 
(8е1 ІпІеггирІ-епаЫе Ріа^ — установка ІР, разрешение 
прерываний). Тем самым будет разрешено выполнение 
других критичных по времени прерываний. Примером 
критичного по времени прерывания может служить 
ввод символа через порт связи и его буферизация. 
Однако инструкция 8ТІ может быть опущена, если 
код обработчика очень короткий. Очистка флага ТР 
(Тгар Ріае) необходима для обеспечения правильной 
работы программ-трассировщиков. Если флаг 
трассировки не сбросить, то и сам обработчик будет 
прерываться после каждой выполненной инструкции, 
что приведет к банальному зависанию. 

Далее ЦПУ сохраняет в стеке текущее значение ре- 
гистра сегмента кода (С8). Затем в С8 заносится зна- 
чение сегмента адреса обработчика прерывания, 
взятое из таблицы векторов прерываний. Таблица 
векторов прерываний находится в нижней части 
памяти — в самом ее начале (стартовый адрес 
0000:0000). Индексация (выборка нужного адреса) в 
таблице производится путем умножения номера 
прерывания на 4 и добавления 2 (для сегментного 
адреса). Двойка добавляется из-за обратного порядка 
записи адресов, принятого в процессорах Іпіеі — 
вначале размещается смещение, а затем сегмент. 


Такое “перевертывание 44 является следствием 
принципа “более значимая информация хранится в 
более старших адресах 44 . (На самом деле никакого 
перевертывания здесь нет. Просто более старшие 
информационные разряды чисел записывается в более 
старших байтах памяти. Так адрес РРРС:08А5 
реально в байтах памяти запишется, как А5 08 РС РР, 
аналогично тому, как слово 25В7 записывается в 
памяти в виде В7 25.) 

После этого в стеке сохраняется скорректированное 
значение указателя инструкций (или счетчика ко- 
манд — ІР — Іпзігисііоп Роіпіег), указывающее на 
следующую за прерванной выполняемую команду. Да- 
лее в ІР заносится смещение обработчика прерываний 
из таблицы векторов прерываний. Индексация смеще- 
ния в таблице производится путем умножения номера 
прерывания на 4. 

В результате этого процесса управление передается 
процедуре, указываемой новой парой адресов С8.ІР, 
т.е. программе обработки прерывания. (На самом деле 
производится просто Гаг-вызов программы-обработчика 
по адресу из таблицы векторов прерываний — 
САІХ РАЯ (ШТ*4), где ШТ — номер прерывания.) 
Как указывалось, одно из первых действий, которое 
выполняет обработчик, это разрешение прерываний 
командой 8ТІ. Затем все регистры, которые обработ- 
чик может модифицировать, сохраняются в стеке. Да- 
лее выполняется непосредственно обработка прерыва- 
ния. По ее завершении значения регистров восстана- 
вливаются. Если обработчик вызывается аппаратным 
прерыванием, он информирует Программируемый 
Контроллер Прерываний (РІС) об окончании обслу- 
живания прерывания посылкой команды (ЕОІ). 

И, наконец, обработчик выполняет инструкцию 
ІЯЕТ. ІЯЕТ возвращает управление прерванному про- 
цессу, выполняя действия, противоположные тем, ко- 
торые выполняются инструкцией ШТ. Первым из 
стека заполняется регистр ІР. Следующее слово вы- 
талкивается в регистр сегмента кода — это адрес сег- 
мента, в котором расположена следующая выполня- 
емая инструкция. Последнее слово выталкивается в 
регистр флагов. 

Этот процесс возвращает управление программе 
точно в то место, где она была прервана. Так как со- 
стояние машины (особенно ее регистров и флагов) 
восстанавливается в исходное, прерываемая программа 
“не чувствует 44 приостановки в работе и продолжает 
выполнение без каких-либо потерь. 

Методика использования таблицы векторов преры- 
ваний упрощает внесение изменений в программы 
прерываний. Все, что нужно сделать — это изменить 
адрес входной точки прерывания в таблице. Наиболее 
общие изменения в программах обслуживания преры- 
ваний происходят при изменениях в операционной 
системе. Например, в 008 3.x вектора прерываний, 
обслуживающих систему, отличны от 1)08 2.x. Анало- 
гично этому, функции обработки прерываний ВІ08 у 
ІВМ РС/АТ и клонов будут различаться, но ЦПУ 
определит правильный адрес в обоих случаях. 
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Подробно о прерывании ШТ 09Н 

Напомним, что все события, связанные с клавиату- 
рой, можно разделить между двумя прерываниями — 
• аппаратным ШТ 09 Н, ответственным за буферизацию 
данных клавиатуры, и программным ШТ 16Н, выби- 
рающим данные из буфера и передающим их при- 
кладной программе. Рассмотрим прерывание ШТ 09Н 
подробнее (см. рис. 1). 



Рис. 1. 

Почти во всех клавиатурах содержится микросхема 
8048. 8048 является однокристальной микро-ЭВМ, со- 
стоящей из 8-разрядного микропроцессора, 64 байт 
ОЗУ и ПЗУ с содержащимися в нем скан-кодами кла- 
виш и программой. При нажатии или отпускании кла- 
виши 8048 ищет в ПЗУ скан-код, присвоенный этой 
клавише. Скан-код — это не то же самое, что А8СІІ- 
код. Например, для клавиши “А“ скан-код равен 1ЕН, 
а А8СІІ коды — 41 Н для прописной А и 61 Н для 
строчной. За преобразование скан-кода ответственно 
прерывание ШТ 09Н. Кроме того, 8048 различает 
этапы нажатия и отпускания клавиш. Отпускание 
клавиши отмечается установкой в 1 старшего бита 
скан-кода. 

После определения правильного скан-кода 8048 
подготавливается к пересылке 1 -байтного кода в схему 
Ь5322, расположенную на системной плате ПК. 
(Наименования микросхем в каждой конкретной ма- 
шине могут быть иными, однако назначение их оди- 
наковое). Скан-код посылается до тех пор, пока про- 
цессор не получит “зеленый свет“ от схемы 874, рас- 
положенной на системной плате, подтверждающий, 
что последний переданный код был прочитан и рас- 
шифрован программой обработки прерывания 
ШТ 09Н. 

Если скан-код не может быть передан непосред- 
ственно в данный момент, он заносится в буфер ОЗУ 
клавиатуры, который я назвал бы буфером скан-кодов. 


(Не следует путать этот буфер с 16-символьным коль- 
цевым буфером в области данных системы, использу- 
емым программой ШТ 09Н для хранения символов.) 
Если буфер скан-кодов полон, то происходит перепол- 
нение и данные теряются. В таком случае 8048 
информирует об этом системный блок, посылая спе- 
циальный скан-код РРН, а прерывание ШТ 09Н ука- 
зывает пользователю на переполнение буфера клави- 
атуры звуковым сигналом. Переполнение, однако, 
происходит довольно редко. Если вам уж так хочется, 
вы можете искусственно добиться переполнения, на- 
жав несколько клавиш одновременно всей ладонью. В 
основном сигнал переполнения служит для обнаруже- 
ния таких стихийных событий, как, например, паде- 
ние книги на клавиатуру. Однако переполнение бу- 
фера клавиатуры может легко произойти в случае, 
если прикладная программа медленно отрабатывает 
нажатия на клавиши. 

Вернемся к нашему примеру. После того, как кла- 
виатура последовательно передаст скан-код буквы А 
(1ЕН), он будет принят в системном блоке схемой 
Ь5328, являющейся 8-разрядным регистром сдвига (см. 
шаг 1 и последующие шаги на рис. 1). Скан-код по- 
сылается последовательным сигналом. Перед данными 
следует стартовый бит, т.е. всего посылается 9 бит. 
Приемный регистр сдвига изначально установлен в 0. 
(Он был очищен в конце предыдущей процедуры 
обработки.) При поступлении каждого б^та, включая 
стартовый, освобождается место для приема следу- 
ющего путем сдвига предыдущих 8 бит регистра на 1 
разряд влево. После получения последнего бита дан- 
ных скан-код вновь преобразуется в исходный 
1 -байтный вид. В регистр сдвига поступило 9 бит, но 
он может удерживать только 8, поэтому прием по- 
следнего бита данных выталкивает из регистра старто- 
вый бит. 

Однако стартовый бит не теряется. Он используется 
для установки триггера 874 в высокое состояние (2), 
что переводит линию запроса прерываний (ІК(21) 
ШТ 09Н в высокое состояние (3). Этот триггер однов- 
ременно посылает низкий уровень процессору 8048 на 
клавиатуре, т.е. дает “красный свет“ по той же самой 
линии данных, по которой был передан скан-код. Это 
запрещает любую передачу данных клавиатурой и пе- 
реводит процессор 8048 в режим буферизации, опи- 
санный ранее. 

Аббревиатура ІК.(} (дословно — “запрос на преры- 
вание“ — Іпіеггирі КечиезО обозначает сигнал, посы- 
лаемый устройством, требующим обслуживания. Для 
разрешения конфликтов, неизбежно возникающих при 
одновременных запросах от нескольких устройств, 
каждому устройству присваивается некоторый уровень 
приоритета. Считается, что наиболее приоритетное 
устройство имеет уровень 0 (в ІВМ РС это системный 
таймер). Для простоты номер приоритета дописыва- 
ется к “ІК(}“. Таким образом ІК(}1 означает запрос на 
прерывание от клавиатуры, имеющей уровень приори- 
тета 1. Для работы с поступающими сигналами ікр в 
компьютере есть Программируемый Контроллер Пре- 
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рываний (РІС) 8259, который и решает на приоритет- 
ной основе, какое из заданий обслуживать первым при 
одновременном поступлении нескольких запросов. РІС 
имеет восемь линий ІК.(}. (РІС однако не ограничен 
восемью запросами. Запросы можно соединять цепью, 
используя один РІС в качестве ведущего, а остальные 
в качестве ведомых. В АТ и РЗ/2 используется допол- 
нительный ведомый РІС для подключения дополни- 
тельных линий ІЯ(}.) Когда РІС получает запрос, он 
устанавливает в Регистре Запросов Прерываний (ІЯЯ) 
бит, соответствующий этому запросу. ІЯЯ — это 
8-разрядный регистр, каждый бит которого использу- 
ется для отслеживания ІВ(}, нуждающегося в обслу- 
живании. Арбитр приоритетов РІС использует этот ре- 
гистр для выбора ІЯ(2 с наивысшим приоритетом. 

Для примера допустим, что запрос от клавиатуры 
ІЯ(}1 является единственным, требующим обслужива- 
ния. РІС устанавливает высокий уровень на линии 
ШТ, передающей запрос на обслуживание клавиатуры 
путем установки высокого уровня на линии Запроса 
Прерываний (ШТК.) ЦПУ. ЦПУ будет поддерживать 
запрос в том случае, если прерывания были перед 
этим разрешены инструкцией 5ТІ. Обычно прерыва- 
ния разрешены, и запрещаются инструкцией СЫ 
только тогда, когда программе необходимо выполнить 
критичное по времени задание, такое как изменение 
указателя стека (8Р) или чтение из порта связи. Само 
прерывание, как уже говорилось ранее, также запре- 
щает прерывания. 

Предположим, что ЦПУ примет прерывание. Тогда 
оно закончит выполнение текущей инструкции, а за- 
тем подтвердит запрос прерывания РІС посылкой 
3-битного кода Контроллеру Шины 8288 (ВС — Виз 
Сопігоііег), как показано в (5). Контроллер Шины 
обеспечивает проход данных к месту назначения. 
3-битный код может управлять 7 типами прерываний 
ВС. Сюда входит и управление сигналом, использу- 
емым ЦПУ для приема или записи данных в память 
или порт. Таким образом происходит разделение 
между инструкциями Ш и ОІП\ предназначенными 
для портов, и инструкцией МОѴ, относящейся к опе- 
рациям с памятью. 

В случае запроса на прерывание 3-битный код, по- 
сылаемый ЦПУ, является кодом сигнала подтвержде- 
ния (“зеленым светом* 4 ), посылаемым контроллером 
шины 8288 назад в РІС 8259А по однобитной линии 
подтверждения прерываний (ШТА) (6). Первый сиг- 
нал % ШТА, посылаемый в 8259А, используется для 
синхронизации, подобно стартовому биту при последо- 
вательной передаче. Следующее 3-битное подтвержде- 
ние от ЦПУ к ВС посылает сигнал ШТА в 8259 для 
начала обработки запроса. Далее 8259 устанавливает 
номер вектора прерываний для ЦПУ (в случае ІК(21 
это ШТ 09Н) (7). 8259 также устанавливает регистр 
І8К так, что РІС может отслеживать, какое прерыва- 
ние в настоящий момент обслуживается. 

А как же РІС 8259 узнает, что ІК(}1 соответствует 
номер 9? Все дело в том, что РІС — программируемое 
устройство, и поэтому начальный код, выполняемый 


при загрузке компьютера, настраивает его нужным 
образом. Одним из действий, выполняемых при этом, 
будет настройка старших 5 бит байта, представля- 
ющего номер прерывания, передаваемого в ЦПУ. При 
формировании номера прерывания младшие 3 бита 
заполняются номером ІЖ}. Таким образом можно ад- 
ресовать 8 векторов от ІЖ}0 до ІК(}7. Единственное 
неудобство здесь состоит в том, что обработчики аппа- 
ратных прерываний, подключенных к одному РІС, 
должны иметь смежные номера. 

В ІВМ РС старшие 5 бит программируются в 
00001В, что при дополнении 3 нулями дает номер 
обработчика таймерного прерывания (ІЖ}0). Таким 
образом, ІК(}1, заполняя младшие 3 бита, составляет 
полный байт равный 00001001В или 09Н. Восемь 
уровней ІК<2 проецируются на прерывания от 
ШТ 08Н до ШТ 0РН. 


Очистка Программируемого 
Контроллера Прерываний 
обработчиком прерываний 


Последнее, что должна выполнять программа обра- 
ботки прерываний — это выдавать сообщение Про- 
граммируемому Контроллеру Прерываний (РІС) об 
окончании прерывания. На ассемблере это выглядит 
так: 


СЫ ; Запрет прерываний 

МОѴ АЬ,20Н ; Посылка неспецифичного конца 

О ЦТ 20Н,АЬ ; прерывания ЕОІ в порт 20Н 

. ; Восстановление всех сохраненных 

; регистров 


ШЕТ 


; Возврат в прерванную программу 


Подробности приведены далее. Если имеются дру- 
гие запросы ІК.(2, ожидающие обработки, то сразу по- 
сле получения сигнала ЕОІ, РІС посылает ЦПУ запрос 
на прерывание. Если прерывания разрешены, (любой 
хороший обработчик прерываний разрешает их, полу- 
чив управление), то ЦПУ обратится к прерываниям. 
Это означает, что обработчик прерываний, заканчива- 
ющий работу, может быть прерван сразу после ин- 
струкции ОЦТ (в нашем примере), до инструкции 
ІКЕТ. Это может показаться безопасным, однако ре- 
зультат будет катастрофическим, если такая ситуация 
повторится много раз подряд. Каждое дополнительное 
прерывание увеличивает стек на 6 байт плюс некото- 
рый объем, используемый обработчиком прерываний 
для сохранения регистров. Многократное вложение 
прерываний означает неконтролируемый рост стека, 
что может привести к перезаписи (порче) информа- 
ции в области данных или кода. В этом случае си- 
стема будет испорчена. 

Что же необходимо сделать для того, чтобы оказа- 
лось достаточно времени для выталкивания из стека 
сохраненных регистров, а также 6 байт (ІР, С8, Ріа^з) 
командой ІКЕТ. Для этого надо запрещать прерыва- 
ния командой СЫ непосредственно перед посылкой 
ЕОІ в РІС. Разрешение прерываний будет выполнено 


5 Зак. 2503 
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командой ІКЕТ. Помимо восстановления С8 и ІР 
ІКЕТ восстанавливает содержимое регистра флагов и 
делает его таким, каким оно было до прерывания. Так 
как бит прерываний (бит, переключаемый инструкци- 
ями СЫ и 8ТІ) в регистре флагов перед возникнове- 
нием прерывания был установлен, то восстановление 
регистра прерываний разрешает прерывания. Стек бу- 
дет очищен и далее спокойно смогут выполняться дру- 
гие прерывания. 

Для понимания того, что означает каждый бит 
байта 20 Н, посылаемого в порт 20Н, необходимо за- 
метить, что схема 8259А имеет много режимов ра- 
боты, но в ПК она работает в режиме по умолчанию. 
В этом режиме ІК.(} выбираются в соответствии с фик- 
сированными приоритетами. Чем меньше номер за- 
проса ІК(2, тем выше его приоритет. ІК(20, ШТ 08Н 
(системный таймер) имеет наивысший приоритет. За- 
прос от клавиатуры ІВДІ, ШТ 09Н имеет второй уро- 
вень приоритета. Принтер (ІК(}7, ШТ ОРН) имеет 
самый низкий приоритет. Прерывание с более низким 
приоритетом не может произойти во время обработки 
прерывания с более высоким приоритетом. Регистр 
обслуживания РІС (І8Ю отслеживает, какое из пре- 
рываний обслуживается. В соответствии с этой логи- 
кой приоритетов РІС считает, что если получен сигнал 
ЕОІ от обработчика прерываний, то нужно выбрать 
следующий по приоритету запрос и начать его обслу- 
живать. Здесь заключена некоторая опасность, состо- 
ящая в том, что если послать лишний ЕОІ, то он бу- 
дет отнесен к следующему, еще не обрабатываемому 
запросу, который будет сброшен. 

Младшие 3 бита 8-битного кода ЕОІ, посылаемого в 
порт 20Н, используются РІС для определения уровня 
приоритета обработчика прерывания, посылающего 
ЕОІ. Так как РІС автоматически определяет уровень, 
то этот специфичный тип ЕОІ не нужен и не исполь- 
зуется. Поэтому младшие 3 бита устанавливаются в 0. 
Верхние 3 бита используются для индикации типа 
ЕОІ; неспецифичный для данного режима тип кодиру- 
ется как 001В. Средние два бита не используются и 
всегда устанавливаются в 0. В результате получаем 
код 00100000В или 20Н. Адрес порта 20Н — это ме- 
сто подключения схемы 8259А — чисто случайно 
имеет то же значение, что и посылаемый сигнал ЕОІ. 

При вызове прерывания ЦПУ использует номер 
прерывания как указатель в таблице векторов, содер- 
жащей адрес программы прерывания (как это было 
рассмотрено ранее). Так как таблица векторов распо- 
ложена внизу памяти, то вектор прерывания ШТ ООН 
размещается в четырех байтах, начиная с самого пер- 
вого байта памяти (0000:0000). Каждый адрес 
(вектор) занимает 4 байта — 2 для сегмента и 2 для 
смещения. Для поиска вектора, связанного с прерыва- 
нием, ЦПУ умножает номер прерывания на 4 и 
использует результат как индекс в таблице векторов. 
Выбранный адрес загружается в пару регистров С8:ІР 
ЦПУ, эффективно передавая управление программе 
обслуживания прерывания. В случае клавиатурного 
прерывания — это обработчик ШТ 09Н. 


Первое, что выполняет ШТ 09Н — получает скан- 
код. Вспомним, что скан-код находится в регистре 
сдвига Ь8322. ШТ 09Н не имеет прямого доступа к 
этой схеме и к скан-коду. Но Ь8322 посылает скан-код 
по 8 параллельным линиям (а не по последовательной 
линии) в порт В (адрес 60Н) другой микросхемы, на- 
зываемой Программируемым Параллельным Интер- 
фейсом (РРІ) 8255-А. 

Помимо обслуживания функций клавиатуры РРІ 
считывает значения переключателей на системной 
плате компьютера и управляет динамиком. Для пре- 
рывания ШТ 09Н РРІ служит источником скан-кодов. 
Программа ШТ 09Н считывает скан-код из порта А, 
преобразует его в символ А8СІІ и запоминает скан-код 
и символ в буфере клавиатуры. Обратите внимание на 
то, что ШТ 09Н — не единственная программа, спо- 
собная считывать из порта А. Так как считывание 
данных из этого порта, в отличие от многих других, 
не уничтожает их, то любая программа может спо- 
койно считывать скан-код. 

После того, как программа ШТ 09Н прочитает 
скан-код, можно дать “зеленый свет" на посылку но- 
вого скан-кода. Это выполняется путем кратковремен- 
ной установки бита 7 порта В в 1 (см. 9 и рис. 2 — 
команды на ассемблере). Бит 7 соединен с линией 
очистки как Ь8322, так и 874. 1,8322 обнуляет выходы 
сдвигающего регистра, подготавливая его к приему 
следующего скан-кода. 874 сбрасывает линию ІК(}1, 
информируя процессор клавиатуры 8048 о готовности 
к приему нового скан-кода. 


Ш АБ.20Н 
ОК АЬ,80Н 
ЗМР $ + 2 

ОІЛГ 20Н,АБ 
АШ АЬ,Ж)Т 80Н 
ІМР $ + 2 
ОІЛГ 20Н,АЬ 


; Ввести текущее состояние порта В 
; Установить старший бит 
; Переход на задержку 
; для быстрых машин 
; Сброс клавиатуры 
; Сбросить старший бит 
; Задержка 

; Восстановить состояние порта В 


Рис. 2. 

Как только скан-код и его А8СІІ-эквивалент будут 
сохранены в буфере, а клавиатура получит разреше- 
ние работы, программе ШТ 09Н остается только со- 
общить РІС, что она завершила работу и передает 
управление прерванной программе (10). Это выполня- 
ется посылкой сигнала ЕОІ, закодированного как 20Н, 
в порт РІС 20Н. Как отмечалось выше, совпадение 
номера порта и кода является чисто случайным. Сиг- 
нал ЕОІ сбрасывает в регистрах І8К и ІКК бит, свя- 
занный с ІЯ(21, освобождая линию запроса. РІС те- 
перь может приступить к обработке аппаратных пре- 
рываний с более низким приоритетом, включая и сле- 
дующий ІК.(}1. 

ШТ 09Н завершает свою работу и передает управ- 
ление прерванной программе путем выполнения ко- 
манды ІКЕТ. Более подробную информацию по 8259А 
смотрите в РегірНегіаІ НапбЬоок (Іпіеі, 1990). . 
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Скан-коды клавиатуры 

Как я уже указывал, ШТ 09Н интерпретирует скан- 
код, поступающий в порт А РРІ 8255А. Фактически 
программа ШТ 09Н выполняется всякий раз при ак- 
тивизации клавиатуры. Сюда относятся нажатие кла- 
виши, ее отпускание, а также удержание в нажатом 


состоянии. Клавиатура просто посылает скан-код в ПК 
программе ШТ 09Н, которая определяет, как его не- 
обходимо интерпретировать. Программа ШТ 09Н, 
расположенная в ВІ05, преобразовывает скан-коды, 
посылаемые клавиатурой, в А5СІІ -символы, которые 
могут использовать прикладные программы. Здесь не- 
обходимо принять во внимание следующее обстоятель- 


Визуальное отображение порта скан-кодов клавиатуры. 
МісНаеІ I. МеЯогсі 


ТТТЬЕ РОКТ-А.А5М 
РАСЕ 60,132 

ТЕХТ ЗЕСМЕЭТ РЫВЫС СООЕ' 
АЗЗІШЕ С8: ТЕХТ 

А551ІМЕ ЭЗГТЕХТ 

ОКО 100Н 
8ТАКТ: ШР МАШ 


: ОАТА АКЕА 



ОВ 

СК,ЗРАСЕ,ЗРАСЕ,ЗРАСЕ,СК,ЬР 

СОРѴКІОНТ 

ВЪ 

“РОКТ- А 1.0 (с) 1990 “ 

РКОСКАММЕК 

ОВ 

“МісЬаеІ 5. МеГГогсі м ,СК,ЬР,ЬР, и $‘ 


ОВ 

СТКЬ_2 

СК 

ЕОИ 

13 

ЬР 

Еди 

10 

СТКЬ 2 

ЕОѴ 

26 

8РАСЕ 

еоѵ 

32 

ВОХ 

Ебы 

254 

ЕЗС ЗСАК 

Едо 

1 

РОКТ А 

Едіі 

60Н 

ВЮЗ ШТ 9 

ОШ 

9 9 
• » • 


МЕМУ ЬАВЕЬ ВѴТЕ 


ИВ “Ргезз апсі геіеазе апу кеу іо зее м 
ИВ м шаке апсі Ьгеак зсап сойе м ,СК.ЬР 

ОВ “Ргезз Езс іо Ехіі“,СК,ЬР,ЬР, и $ и 

; СОРЕ АКЕА 


МАIN 

САІХ 

МОѴ 

МОѴ 

ЮТ 

МОѴ 

ют 

МОѴ 

ют 

МОѴ 

МОѴ 

МОѴ 

МОѴ 

ют 


РКОС ЖАК 

сьз 

РХ,ОРРЗЕТ СОРѴКІСНТ 

АН, 9 

21Н 

РХ,ОРР8ЕТ МЕШ 
21Н 

АХ,3509Н 

21Н 

ВЮЗ ЮТ 9[0],ВХ 
ВЮ5“ШТ^9[2] ,ЕЗ 
РХ,ОРРЗЕТ РОКТ А ЮТ 
АХ,2509Н 
21Н 


; Очистка экрана 
; Вывод Соругі^Ьі и меню 


; Получить прерывание 
; клавиатуры 

; Сохранить старое 
; прерывание 
9 ; Установить новый 

; вектор 


; Находиться в цикле до появления Езс 


СЕТ КЕУ: 

ХОК АН, АН 
ШТ 16Н 

СМР АН,Е8С ЗСАК 
Ш2 СЕТ КЕѴ 
ЕХГГ: 

МОѴ РХ,ВІ05 ЮТ 9 [0] 
МОѴ РЗ,ВІОЗЮТ“9[2] 
МОѴ АХ,2509Н ” 

ШТ 21Н 
САІХ СЬЗ 
МОѴ АХ,4С00Н 
ЮТ 21Н 


; Ожидать нажатия на клавишу 

; Если Езс, выход 
; Иначе — продолжить 

; Восстановить старый 
; вектор ШТ 9 


; Очистить экран. 

; Выход с еггог Іеѵеі = 0 


МАШ ЕЖР 


ПОДПРОГРАММЫ 


; Данная процедура вызывается каждый раз при нажатии 
; на клавишу и ей передается значение, что позволяет 
; взглянуть на скан-код и отобразить его 

РОКТ А ЮТ 9 РКОС ЖАК 
А55СМЕ РЗШОТНШС 


РИЗН АХ 
РЫЗН ВХ 
РИЗН СХ 
Ш АЬ,РОКТ А 
САІХ НЕХ ОІГГРЦТ 
ОШ ЮТ 9: “ 

РОР СХ 
РОР ВХ 
РОР АХ 

ІМР ОШОКИ РТК ВЮЗ 
РОКТ А ЮТ 9 ЕШР 


; Сохранить регистры 

; Получить скан-код 
; и отобразить его 

; Восстановить регистры 
МТ_9 ;переход на ВЮЗ ЮТ 9 


; Сохранить число в ВХ 
; 4 позиции/слово; 4 бита/символ 

; Старшие биты в младшие 
; Сохранить число в АЬ 
; Маскировать все, ююме четырех 
; Преобразовать в АЗСІІ 
; Буква* 

; Если нет — печать 
; Иначе — подстроить 

; Печать через ВЮЗ 

; Все сделано для этих позиций? 
КОТАТЕНЕХ ; Если нет, взять следующую 
; Вывести два пробела 
; между скан-кодами 
; в качестве разделителей 


НЕХ ОІЛГРЦТ РКОС ЖАК 
МОѴ ВХ,АХ 
МОѴ СХ,204Н 
КОТАТЕ НЕХ: 

КОЬ ВЬ.СЬ 
МОѴ АЬ,ВЬ 
АN^ АЬ,1 111В 
АВВ АЬ, м 0 м 
СМР АЬ,“9“ 

ЛХ РКЮТ НЕХ 
АОИ АЬ,7 ” 

РКЮТ НЕХ: 

МОѴ” АН,0ЕН 
ЮТ ЮН 
ВЕС СИ 
Ш2 

МОѴ СХ,2 
ОЕЫМІТ: 

МОѴ АЬ,5РАСЕ 
МОѴ АН,0ЕН 
ЮТ ЮН 
ШОР ОЕІЛМГГ 
КЕТ 

НЕХ_ОІЛГРЦТ ЕЖР 

СЬЗ РКОС ЖАК 
МОѴ АН,0РН 
ЮТ ЮН 
СМР АЬ,7 

12 СЬЕАК ЗСКЕЕК 
МОѴ АЬ,3 “ 

СЬЕАК ЗСКЕЕІѴГ: 

ХОК “АН, АН 
ШТ ЮН 
МОѴ АХ,500Н 
ЮТ ЮН 
КЕТ 


; Текущий видео режим 
; Моно? 

; Если да — очистить экран 
; Иначе проверить, 

; что текстовый 

; Очистить экран 
; установкой режима 
; Убедиться, что страница 
; нулевая 


СЬЗ ЕЖР 
ТЕХТ ЕЖ5 

ЕЖ 5ТАКТ 


Рис. 3. 
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КЛАВИАТУРА: ОТ А ДО Ъ 


ство. ШТ 09Н является аппаратно-зависимой фун- 
кцией, поэтому программа для 83-клавиш ной клави- 
атуры отличается от версии программы для расширен- 
ной 101 -клавишной клавиатуры. Очевидно, что для 
связи букв с дополнительными клавишами требуются 
дополнительные коды. 

Для лучшего понимания обратимся к программе 
РОКТ-А.А5М (рис. 3), которая в реальном времени 
отображает скан-коды, посылаемые при нажатии и 
отпускании клавиш (клавиатура посылает скан-коды в 
порт А РРІ, адрес 60Н.) Скан-коды считываются про- 
граммой РОКТ-А до того, как программа ШТ 09Н до- 
берется до них, путем перехвата прерывания 09Н. Пе- 
рехват прерывания означает замену адреса прерыва- 
ния в таблице векторов прерываний на адрес своей 
программы обработки. Исходный адрес при этом запо- 
минается и, как только программа РОКТ-А или любая 
другая перехватившая программа завершится, управ- 
ление может быть передано первоначальному обработ- 
чику прерываний. (Хотя перехват прерываний похож 
на передачу управления ТЗК-программе при нажатии 
“горячей клавиши 44 , РОКТ-А.А5М не является ТЗК- 
программой.) При нажатии клавиши Езс программа 
РОКТ-А восстанавливает прежнее значение в таблице 
векторов прерываний и возвращается к приглашению 
ООЗ. ■ Остальные подробности программы описаны в 
комментариях в листинге программы. Вы можете 
скомпилировать представленный код. 

После запуска программы РОКТ-А при любом на- 
жатии на клавишу на экране появляется скан-код этой 
клавиши. При отпускании этой клавиши на экране 
появляется другой скан-код. Для 83-клавишной клави- 
атуры код отпускания равен коду нажатия плюс 80Н 
(10000000В), что устанавливает старший бит скан- 
кода. Это также верно и для большинства клавиш 
расширенной клавиатуры, однако для новых 
(дополнительных) клавиш — специализированных 
клавиш курсора и некоторых комбинаций клавиш — 
посылается серия скан-кодов, некоторые из которых 
имеют старший бит, установленный в 1 даже при на- 
жатии на клавишу. До появления расширенной клави- 
атуры пользователи могли легко отличить нажатие 
клавиши от отпускания проверкой старшего бита 
скан-кода. Этот способ не работает с расширенной 
клавиатурой. Программа РСЖТ-А может стать удо- 
бным инструментом для определения скан-кодов, ко- 
торые должна обрабатывать программа ІЫТ 09Н при 
нажатии на ту или иную клавишу. Работа программы 
РОКТ-А вполне понятна, однако значения выводимых 
скан-кодов поначалу кажутся весьма странными. Все 
становится ясно после понимания работы ШТ 09Н. 
Для этого рассмотрим логику декодирования про- 
граммы ШТ 09Н шаг за шагом. 

Скан-код, считываемый программой ШТ 09Н из 
порта А, в большинстве случаев является числом, 
представляющим собой относительное положение кла- 
виши на клавиатуре. Так, скан-код 01 Н относится к 
клавише Езс, 02Н — к клавише !/1, ОЗН — @/2 и 
т.д. слева направо по верхнему ряду клавиатуры. В 


отличие от большинства компьютерных схем нумера- 
ции, отсутствует клавиша, связанная с кодом 0. 
ШТ 09Н использует 0 как псевдо-скан-код для ото- 
бражения комбинации Сігі-Вгеак. После клавиши 
ВаскЗрасе последовательная нумерация возобновляется 
с клавиши ТаЬ в ряду (^\УЕКТУ. После перечисления 
клавиш пишущей машинки нумерация продолжается 
на функциональных клавишах, а далее — на допол- 
нительных. Некоторые клавиши, такие как Езс и фун- 
кциональные, на разных клавиатурах расположены в 
разных местах, поэтому для них система нумерации 
не имеет смысла. Для сохранения совместимости скан- 
коды остаются теми же. Помните, что скан-код не 
имеет ничего общего с АЗСІІ-эквивалентом клавиши. 




Статус ІпяеіТ: 1= 

-включен 
с1=еключеи 
: 1 = включен 
А: 1=еключен 


І 9 < 
111 

ттншшишн 

Состояние АН; 1=иажата^ 

Состояние СЫ: 1=иажата ' 

Состояние Левый ЗЬгН: 1=иажат — 
Состояние Правый ЗЬгН: 1 =иажат 



Рис. 4, 


Для дешифровки скан-кодов ШТ 09Н содержит 
специальную таблицу поиска. Для поиска 
соответствия в таблице используется ряд алгоритмов. 
Как только скан-код расшифрован, ШТ 09Н 
сохраняет скан-код и АЗСІІ-символ в буфере 
клавиатуры и возвращает управление прерванной 
программе. Однако до передачи управления ШТ 09Н 
проверяет, не является ли скан-код кодом РЕН. Как 
упоминалось выше, код РРН является кодом 
клавиатуры, указывающим на переполнение. При 
обнаружении такого кода ШТ 09Н сообщает об этом 
сигналом динамика. В противоположном случае, 
полагая, что переполнение отсутствует, ШТ 09Н 
просматривает таблицу Перевода в. логическом 
порядке. Сначала проверяются клавиши смены 
функций: клавиши сдвига — левый и правый ЗНіН, 
Сігі, АИ и четыре фиксируемые клавиши — Іпзегі, 
СарзЬоск, ЫшпЬоск, ЗсгоІІЬоск. Если скан-код при- 
надлежит одной из четырех клавиш сдвига, это ото- 
бражается установкой соответствующего бита в 
информационном байте КО_РЬАС, расположенном по 
адресу 40:17Н в области данных ВІ05 (рис. 4). При 
обнаружении скан-кода отпускания клавиши сдвига 
соответствующий бит сбрасывается в 0. Такой метод 
позволяет программе ШТ 09Н всегда знать, какая из 
этих клавиш нажата. 

Клавиши сдвига 

Лучший способ проиллюстрировать логику работы 
клавиш сдвига — это посмотреть, что происходит до и 
после расшифровки скан-кода программой ШТ 09Н. 
Сначала рассмотрим, как ШТ 09Н отработает на- 
жатие нескольких клавиш в командной строке ООЗ. 
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Нажмем и будем удерживать левую клавишу ЗНіН. 
Внешне ничего не происходит. Продолжая удерживать 
левый ЗЬіН, нажмем клавишу “А“. Как и ожидалось, 
появится прописная буква А (полагаем, что клавиша' 
СарзЬоск не включена), а вслед за ней — целый ряд 
прописных А, возникающих вследствие работы фун- 
кции автоповтора клавиатуры. Отпустим левый 8ЫН, 
продолжая удерживать клавишу “ А“ нажатой. Про- 
писная А заменится на строчную а, а функция авто- 
повтора продолжит свою работу. 

При помощи программы Рогі-А можно увидеть, что 
в действительности происходит со скан-кодами. На- 
жмите Езс для отмены ничего не значащей команды 
ААААААаааа и запустите программу РОКТ-А. После 
этого повторите те действия, которые вы выполняли в 
командной строке 005 — начните с нажатия и удер- 
жания левой клавиши 8ЫН. Появится и будет повто- 
ряться скан-код 2АН. (Клавиатура начинает автопов- 
тор примерно через 0,5 секунды, если не изменена за- 
держка. Это справедливо для всех клавиш, включая и 
клавишу 5ЫН.) Продолжая удерживать клавишу ЗНіН 
нажатой, нажмите клавишу “А“. Поток кодов 2АН 
заменится на 1ЕН — скан-код клавиши “А“. 
(Автоповтор прекратится, как только клавиатура 
обнаружит, что нажата другая клавиша. Если удержи- 
вать и вторую клавишу, то начнется автоповтор этой 
клавиши.) 

Далее отпустите клавишу 5ЫН, но не клавишу “А“. 
В потоке скан-кодов 1ЕН, принадлежащих клавише 
“А“, появится один код ААН, а затем возобновится 
поток кодов 1ЕН. Обратите внимание на то, что в 
отличие от работы в БОЗ, где поток прописных А за- 
меняется на поток строчных а, в данном случае отпус- 
кание клавиши 5ЫН не изменяет скан-кода. 
Отпустите клавишу “А“; вывод закончится кодом 
9ЕН — отпускание клавиши (1ЕН+80Н = 9ЕН). 

Проверка байтов Статуса Сдвига 
и Состояния Сдвига 

(Перед выполнением этих упражнений удалите из 
файла АІІТОЕХЕС.ВАТ все резидентные программы 
обслуживания клавиатуры, например, ООЗЕОІТ.) 

Для того, чтобы увидеть изменение КО_РЬАС, за- 
пустите отладчик ОЕВІЮ и по подсказке в виде знака 
минус введите: 

О 40:17 Ы (дамп сегмента 40Н, смещение 17Н, 
длина 1 байт) 

На экране появится состояние байта КО_РЬАС (см. 
рис. 4) Описанные ниже действия будет проще вы- 
полнить, если его значение равно 0. Если оно не 
равно 0, то это означает, что нажата одна из клавиш 
сдвига. При необходимости переключите клавиши 
сдвига (Іпзегі, СарзЬоск, ЫишЬоск и/или ЗсгоІІЬоск) и 
повторите приведенную выше команду. В конце кон- 
цов вы увидите 0. Во время работы с ОЕВІЮ можно 
использовать клавишу РЗ для повтора последней ко- 
манды. 


Нажмите РЗ для отображения команды О 40:17 Ы, 
но пока не нажимайте Епіег. Сначала нажмите Іпзегі 
для включения режима вставки и после этого нажмите 
Епіег. Вы увидите значение 80Н, указывающее на то, 
что режим вставки активен. Снова нажмите Іпзегі для 
его деактивации, затем по одной нажимайте другие 
фиксируемые клавиши сдвига (СарзЬоск, ЫшпЬоск, 
ЗсгоНІюск). Нажимая РЗ и Епіег после каждого из пе- 
реключений, наблюдайте производимый эффект. Про- 
верьте, соответствуют ли полученные значения приве- 
денным на рис. 4. 

Далее нажмите СарзЬоск и ЫитЬоск. Нажмите РЗ 
и Епіег. На этот раз вы увидите значение, являющееся 
комбинацией отдельных битов, а именно, 60Н 
(40Н+20Н). Заметьте, что указанным способом нельзя 
наблюдать состояние клавиш Сігі и АН в байте 
КВ_РЬАС, так как комбинации Сігі-Епіег и АИ-Еп1ег 
не генерируют возврата каретки. 

Теперь проделайте подобные операции с байтом со- 
стояния клавиш КП_РЬАС1, расположенным по ад- 
ресу 40:18 в области данных ВІОЗ. Введите: 

и 40:18 Ы 

На этот раз вы увидите 0, независимо от состояния 
фиксируемых клавиш. КО_РЬАС1 используется ВІОЗ 
для отслеживания нажатия нескольких клавиш однов- 
ременно. Для того, чтобы это увидеть, повторите пре- 
дыдущую команду, не нажимая клавиши Епіег, затем 
нажмите и удерживайте клавишу Іпзегі и нажмите 
Епіег. Вы увидите значение 80Н, указывающее на то, 
что клавиша Іпзегі находится в нажатом состоянии. 
Проэкспериментируйте с другими клавишами сдвига, 
проделывая эту же процедуру. Для выхода из отлад- 
чика введите (}. 

Как можно заметить, программа ШТ 09Н интер- 
претирует скан-коды в виде строчных и прописных 
букв. В действительности, при нажатии на левый ЗЬіН 
программа ШТ 09Н получает код 2АН и устанавли- 
вает (оператором (Ж) бит левой клавиши ЗНіН (бит 1) 
в байте КО_РЬАС. Та же логика используется и при 
автоповторе клавиши ЗЬіН. Последовательная уста- 
новка одного и того же бита не приводит к каким- 
либо изменениям. Если нажимается клавиша “А 4 *, то 
ШТ 09Н обнаруживает скан-код 1ЕН, соответству- 
ющий строчной букве а. В то же самое время 
ШТ 09Н проверяет состояние двух клавиш ЗНіН, про- 
сматривая содержимое байта КП_РЬАС. Программа 
обнаруживает, что левый 5ЫН еще нажат, поэтому 
строчная а становится прописной А. 9 

Прежде чем запомнить А в буфере клавиатуры, 
ШТ 09Н проверяет бит, соответствующий состоянию 
клавиши СарзЬоск (7) в байте КО_РЬАС. Если Сар- 
зЬоск выключен, то ШТ 09Н заносит в буфер пропис- 
ную А. Если же СарзЬоск включенг то А снова стано- 
вится строчной а, тем самым отменяя СарзЬоск. 

Далее, при отпускании левой клавиши ЗЫК 
ШТ 09Н обнаруживает скан-код ААН 
(ААН * 2АН+80Н) и сбрасывает бит левой клавиши 
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КЛАВИАТУРА: ОТ А ДО Ъ 


5НІН в байте КО_РІАС. При поступлении следующего 
кода 1ЕН ШТ 09Н обнаруживает, что левый 8ЫМ 
больше не нажат (а также не нажаты ни правый ЗЬШ, 
ни СарзЬоск) и записывает в буфер строчную а. 

Та же логика смены функций используется и при 
обработке нажатий клавиш цифровой клавиатуры. 
Если включен ЫшпЬоск, то нажатие левой или правой 
клавиши 8ЫН перед нажатием клавиши на цифровой 
клавиатуре отменяет установленный статус, тем са- 
мым превращая клавиши цифр в клавиши управления 
курсором. Такая гибкость особенно полезна для поль- 
зователей 83-клавишной клавиатуры, которые обычно 
оставляют ЫигаЬоск включенным. Когда необходимо 
использовать цифровую клавиатуру для управления 
курсором, то вместо переключения ЫитЬоск доста- 
точно нажать левый 8ЫН и удерживать его. 

У 101 -клавишной клавиатуры наряду с блоком 
цифровой клавиатуры имеются специализированные 
клавиши управления курсором. Машины с такими 
клавиатурами обычно при загрузке включают Ыига- 
Ьоск, поэтому клавиатура готова для ввода чисел. 
Однако некоторым пользователям трудно побороть 
привычку и они продолжают использовать цифровую 
клавиатуру для управления курсором. Так как при за- 
грузке устанавливается ЫшпЬоск, то при первой по- 
пытке управления курсором на экране появляется 
строка цифр. Для 83-клавишной клавиатуры наблюда- 
ется обратная ошибка. Однако можно включать эти 
клавиши из ЬаісЬ-файла, например из АІІ- 
ТОЕХЕС.ВАТ (см. рис. 5). 


КСХ 

С 

А 

МОѴ АХ, 0040 

МОѴ 08, АХ 

ХОК Вуіе Ріг [00171,80 

ШТ20 

N ШЗЕКТ.СОМ 
Е 109 40 

N САРЗЬОСК.СОМ 
\Ѵ 

Е 109 20 

N ШМШСК.СОМ 


можно использовать в пакетных файлах для включе- 
ния того или иного состояния. Для некоторых расши- 
ренных клавиатур данные программы не будут вклю- 
чать соответствующие светодиодные индикаторы, 
однако результирующее состояние будет верным. 

Клавиши-переключатели 

Логика работы клавиш-переключателей (Іпзегі, 
СарзЬоск, ЫшпЬоск и ЗсгоІІЬоск) отличается от логики 
работы клавиш сдвига. Когда программа ШТ 09Н 
встречает скан-код клавиши-переключателя, она под- 
готавливается к установке (с использованием опера- 
тора ОК) соответствующего бита в байте КО_РІАС1. 
Так как все биты в КО_РІАС уже заняты, то для хра- 
нения состояния этих клавиш используется второй 
байт (см. рис. 6). Перед установкой этого бита 
ШТ 09Н проверяет, не был ли он установлен ранее. 


Г 


Клавиша ІпхоП. 1=мажата 
Клавиша Сар*1_оск: 1=иажата 
Клавиша МитЬоск: 1=нажата 
Клавиша ЗсгоІІЬвск: 1=нажата 


3 

Г-Т 


СЫ-Ыит-Ьоск (Раиде) 

1 01 -клавишная ЗузРЦ 

101 -клавишная, левый АН — 
101 -клавишная, правый АН - 


Рис. 6. 


Если был, то ШТ 09Н считает, что произошел авто- 
повтор, и не предпринимает никаких действий. С по- 
мощью программы РОКТ-А можно увидеть, что нажа- 
тие или отпускание СарзЬоск действует точно так же, 
как нажатие и отпускание любой другой клавиши, при 
этом так же посылается набор скан-кодов в случае ав- 
топовтора. Если не использовать дополнительную ло- 
гику переключения, то автоповтор приведет к непред- 
сказуемым и нежелательным переключениям. Если 
бит еще не установлен, то он устанавливается, указы- 
вая на то, что клавиша нажата. Также переключается 
бит в КО_РІАС для индикации смены состояния (это 
выполняется операцией ХОЮ. Для просмотра содер- 
жимого КО_РЬАС в вашем компьютере вос- 
пользуйтесь рекомендациями, приведенными выше. 

Набор символов через АН 


Б 109 10 

N 8СКОШСК.СОМ 

ѵг 

а 


Рис.5. 

Вы можете создать файл, текст которого приведен 
ниже, и направить его в отладчик командой 

ЭеЬи* < ТОССЬЕ.ЗСК. 

либо ввести инструкции непосредственно, находясь в 
отладчике. Результирующие файлы Ш8ЕКТ.СОМ, 
САР8ШСК.СОМ, МІШШСК.СОМ и 8СКОШСК.СОМ 


Программа ШТ 09Н специальным образом обраба- 
тывает комбинации клавиши АН с клавишами цифро- 
вой клавиатуры. Если клавиша АН нажата (ШТ 09Н 
определяет это по биту 3 в КО_Р1АС), и если обна- 
руживается скан-код цифровой клавиши, то ШТ 09Н 
добавляет число, нарисованное на клавише, к байту по 
адресу 40:19 в области данных ВЮЗ — АЬТ_ШРШ\ 
Предыдущее значение АЕТ^ШРИТ умножается на 10 
(для сдвига десятичной точки вправо на одйу пози- 
цию) прежде, чем будет добавлено новое число. При 
отпускании клавиши АН полученное таким образом 
число интерпретируется как десятичный эквивалент 
АЗСІІ-кода и помещается в буфер клавиатуры. Для 
примера, в командной строке И08 нажмите клавишу 
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АИ и, удерживая ее, нажмите и отпустите клавишу 6, 
а затем 5 на цифровой клавиатуре. Отпустите кла- 
вишу АИ — на экране появится буква А, А5СІІ-код 
которой равен 65. При отпускании АН ДОТ 09Н сбра- 
сывает АІЛМДОРІГГ в 0. Если при отпускании АИ зна- 
чение АІЛМЫРІГГ равно 0, то ввод не производится, 
что объясняет невозможность ввода нуля (А5СІІ — 
ноль) с помощью этого метода. 

Этот альтернативный метод ввода работает только с 
цифровой клавиатурой, но не с числовыми клавишами 
в верхнем ряду. Состояние ЫишЬоск не имеет значе- 
ния. Метод набора через АИ используется для ввода 
символов управления и псевдографики. 

Состояние удержания 

Если не нажаты клавиши сдвига или кла- 
виши-переключатели, ДОТ 09Н проверяет бит 3 в 
байте КО^РЬАСН для определения активности состо- 
яния паузы. Если этот бит установлен, что подразуме- 
вает пребывание машины в ‘‘заморожен ном 44 состо- 
янии, то он сбрасывается и ДОТ 09Н прекращает ра- 
боту. Бит 3 устанавливается нажатием комбинации 
СігІ-ЫишЬоск на 83-клавишной клавиатуре, или спе- 
циализированной клавиши Раи$е на 101 -клавишной 
клавиатуре. Для “замораживания 44 машины ДОТ 09Н 
зацикливается сразу после установки бита паузы, 
ожидая его сброса. Сброс осуществляется при нажатии 
на любую клавишу, за исключением клавиш сдвига. 
Это происходит потому, что проверка состояния кла- 
виш сдвига выполняется раньше, чем проверка состо- 
яния бита паузы. 

Для примера, дайте команду 005 ЭІК, а затем, во 
время вывода каталога на экран, нажмите 
СігІ-ЫишЬоск на 83-клавишной клавиатуре или Раизе 
на 101 -клавишной для остановки вывода (желательно, 
чтобы каталог был большим). Теперь нажмите любую 
клавишу сдвига. Состояние изменится, однако 005 не 
возобновит вывод списка кат&аога. 

Комбинация клавиш СігІ-5 тоже останавливает вы- 
вод каталога, однако это реализовано не программой 
ДОТ 09Н. СігІ-5 обрабатывается и вводится в буфер 
клавиатуры точно так же, как и любой другой символ, 
а 005 уже интерпретирует ее как команду паузы. 

агІ-АН-ВеІ 

Комбинация СігІ-АИ-ОеІ имеет специальное назна- 
чение. При ее обнаружении в ячейку КЕ5ЕТ_РІАС, 
находящуюся в области данных В105, заносится зна- 
чение 1234Н и выполняется переход на процедуру 
инициализации, которая выполняется обычно при 
включении компьютера. Программа инициализации 
проверяет КЕЗЕТРЬАС и пропускает самопроверку в 
том случае, если его значение равно 1234Н. Таким 
образом осуществляется “теплая 44 перезагрузка. 

Если вы обратитесь к байту К0_Р1АС, то заметите, 
что в нем зарезервированы биты для индикации состо- 
яния клавиш Сігі и АН, но не Оеі. Бита состояния 
клавиши Беі нет также и в КВ_РІАС1. Это означает, 
что ДОТ 09Н не имеет возможности хранения состо- 


яния клавиши Оеі. Поэтому для перезагрузки необхо- 
димо сначала нажать клавиши Сігі и АН а затем Оеі. 
Порядок нажатия клавиш Сігі и АН не имеет значе- 
ния, важно только нажать Оеі в последнюю очередь. 

Сігі-Вгеак 

При обнаружении этой комбинации ДОТ 09Н вы- 
полняет несколько действий. Сначала очищается бу- 
фер клавиатуры путем установки указателя начала 
буфера равным указателю конца. Затем ДОТ 09Н 
устанавливает в 1 старший бит байта ВІ05_ВКЕАК с 
адресом 40:71Н в области данных ВІ05. Любая про- 
грамма может проверить значение этого бита для 
определения состояния Сігі-Вгеак. Затем ДОТ 09Н вы- 
зывает прерывание ДОТ 1ВН. Обычно ДОТ 1ВН указы- 
вает на обработчик 005, но любая программа может 
перехватить этот вектор и тем самым самостоятельно 
обрабатывать Сігі-Вгеак. Если прерывание ДОТ 1ВН 
вызывает обработчик 005, то последний устанавли- 
вает внутренний флаг Сігі-Вгеак 005. При этом лю- 
бая программа, использующая функции ввода/вывода 
005 при взведенном флаге Сігі-Вгеак (Сігі-Вгеак 005 
а не ДОТ 09Н), будет прервана. 005 отобразит на эк- 
ране значок “*С“ и выведет приглашение командной 
строки. Последнее, что делает ДОТ 09Н с 
Сігі-Вгеак — это помещает нулевой символ и скан-код 
в буфер клавиатуры. 

Ввод Сігі-С тоже интерпретируется как Сігі-Вгеак. 
Выполнение этой команды, так же как и выполнение 
СігІ-5, не является функцией ДОТ 09Н. Сігі-С обраба- 
тывается ДОТ 09Н в той же последовательности, как и 
любой другой символ, а уже 005 сама интерпретирует 
ее как команду прерывания. 

Ргіпі Зсгееп 

При нажатии комбинации 5Ніі1-Ргі5сгп на 
83-клавишной клавиатуре или специальной клавиши 
Ргіпі5сгееп на 101 -клавишной, ДОТ 09Н просто вызы- 
вает ДОТ 05Н для посылки дампа экрана на принтер. 
ДОТ 09Н непосредственно печатью не занимается. 

Алфавитно-цифровые клавиши 

Если ДОТ 09Н не обнаруживает специальных скан- 
кодов, то она полагает, что принятый скан-код при- 
надлежит алфавитно-цифровому символу А5СІІ. Для 
алфавитно-цифровых символов ДОТ 09Н проверяет со- 
стояние СарзЬоск. Затем ДОТ 09Н заносит в буфер 
как сам А5СІІ-символ, так и скан-код нажатой кла- 
виши. Это дает возможность прикладной программе 
либо прочитать АЗСН-символ, либо определить нажа- 
тую клавишу. Однако, прежде чем что-либо занести в 
буфер программа ДОТ 09Н должна проверить, есть ли 
в нём место. Если места недостаточно, то ДОТ 09Н со- 
общает об этом сигналом динамика и завершает свое 
выполнение без занесения символа в буфер. 

М. Меффорд 

(Окончание следует) 
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Страна по имени 

ВОКІ.АИО 


Сегодня специальный выпуск “ КомпьютерПресс “ впервые 
посвящен продуктам одной-единственной фирмы. Но 
диапазон ее деятельности настолько широк, что мы считаем 
себя просто не вправе не уделить должного места ей в своем 
журнале, и имя этой фирмы — Вогіапсі 
И как только ухитряется Филипп Кан со своей командой 
настолько диверсифицировать свою деятельность, чтобы 
производить и превосходные оболочки, и электронные 
таблицы, и базы данных, и компиляторы — практически все, 
что только нужно пользователю персонального компьютера. 
А чего стоит последняя покупка Вогіапй, ни мало, ни много — 
сама АзШоп-ТаІе, в устойчивости которой, несмотря на 
известную неудачу с йВАЗЕ IV, не сомневался практически 
никто. 

Пять статей, включенных в этот выпуск, посвящены со- 
ответственно истории и современной стратегии фирмы, 
объектно-ориентированному программированию на ТигЬо 
Разсаі, версии ТигЬо Разсаі, работающей в среде Шпйот, 
системе управления базой данных Рагайох и генератору 
отчетов ОЪ]есіѴізіоп. 

Что еще хотелось бы сказать по поводу этого спецвыпуска. 
Все описываемые здесь продукты давно и весьма успешно 
продаются рядом совместных предприятий в СССР и, что 
примечательно, за советские рубли по коэффициенту, 
который значительно ниже рыночного. А сейчас по вполне 
достоверной информации Вогіапсі, наконец-то, открыла собс- 
твенное представительство в Москве, и в ближайшем бу- 
дущем выйдет на советский рынок без посредников. 

А теперь, знакомьтесь — Страна по имени Вогіапй. 
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л\юрпорация Вогіагиі Іпіетаііопаі 
(США), один из крупнейших 
производителей программных средств 
для персональных компьютеров в мире, 
активно работает на советском рынке 
с 1990 года. Количество официально 
закупленных в СССР программ Вогіапсі 
измеряется тысячами, а число 
нелегально используемых копий — 
миллионами. Среди партнеров Вогіапсі в 
СССР крупнейшие совместные 
предприятия: “ Интеркв адро“, концерн 
“Новинтех“, А/О “ Диалог-МИФИ “, 
объединение КАТ и некоторые другие 
фирмы. 


Рынок программных 
средств в СССР: 

мирное наступление Вогіапсі 


Программисты и пользователи часто относятся к 
программам, как к живым существам: наделяют их 
“характером", “привычками", серьезно оценивают 
внешний вид и “поведение". Особенно часто характе- 
ристики из этого ассоциативного ряда применяются к 
наиболее популярным, “нравящимся" программам. На 
протяжении последних лет многократно приходилось 
слышать антропоморфные эпитеты в адрес програм- 
много обеспечения, поставляемого американской кор- 
порацией Вогіапсі (Вогіапсі Іпіетаііопаі, Іпс.). В чем 
причины такого отношения? Почему практически на 
каждом персональном компьютере в СССР можно 
обнаружить тот или иной продукт Вогіапсі? Как, не 
впадая в апологетику Вогіапсі, объяснить тот факт, что 
опросы, проводимые в СССР, постоянно показывают 
наивысший интерес советских программистов именно 
к изделиям фирмы Вогіапсі? 

В предлагаемом Вашему вниманию спецвыпуске де- 
лается попытка ответить на эти вопросы, объяснить и 


проиллюстрировать отношение потребителей к про- 
дукции фирмы. В данной статье анализируются неко- 
торые причины технологического и коммерческого 
успеха корпорации Вогіапсі, дается ретроспектива де- 
ятельности Вогіапб в СССР. 

Вогіапсі: воплощение “американской мечты“ 

Чтобы понять феномен Вогіапсі на советском рынке, 
следует вернуться в 1983 год — в этом году молодой и 
предприимчивый математик, Филипп Кан (РНПірре 
КаНп), предложил на американский рынок програм- 
мных средств язык программирования Разсаі по цене 
$49.95 — на порядок меньше, чем у известных фирм- 
конкурентов. В этом продукте был реализован целый 
ряд оригинальных идей, облегчавших труд программи- 
ста. Спрос превысил все ожидания! Программный 
продукт, получивший название ТигЬо Разсаі, стал 
первым громким коммерческим успехом созданной 
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Каном корпорации, которая получила название Вог- 
ІапсІ Іпіегпаііопаі (в дальнейшем — Вогіапсі). 

К середине 80-х определились три стратегических 
направления деятельности Вогіапсі: языки программи- 
рования, системы управления базами данных, элек- 
тронные таблицы. 

В области языков программирования Вогіапсі штур- 
мом взял рынок программных средств, выпуская по 
неслыханно низким ценам все более и более совер- 
шенные версии ТигЬо Разсаі. Для большинства потре- 
бителей оказалось дешевле закупить легальную копию 
продукта, чем раздобыть похищенные копии програм- 
много обеспечения, а потом ломать себе голову над 
тем, где бы скопировать документацию. 

Такая коммерческая тактика Вогіапсі сохранилась и 
для других разработок, с той лишь только разницей, 
что в каждое новое изделие вкладывалось беспреце- 
дентное количество технологических новаций. Коли- 
чество проданных во всем мире копий языков прог- 
раммирования семейства ТигЬо (ТигЬо Разсаі, 
ТигЬо С, ТигЬо АззетЫег) измеряется в настоящее 
время миллионами! 

К 1990 году единственным серьезным конкурентом 
Вогіапсі на рынке языков программирования можно 
было считать, пожалуй, корпорацию МісгозоН. Но в 
лабораториях Вогіапсі уже было разработано секретное 
оружие: набор программных средств, основанный на 
объектно-ориентированном программировании (ООП). 
Этот подход к созданию программных средств эволю- 
ционировал, начиная с 60-х годов (ЗшаІІТаІк, Зітиіа). 
Его основные преимущества сводятся к многократному 
повышению производительности труда программистов, 
особенно, — ведущих коллективные разработки. 
Исходные тексты программ, разработанных на основе 
ООП, могут легко обобществляться разработчиками. 
Упрощается и процесс развития и дополнения дей- 
ствующих программ новыми возможностями. По сути 
дела, исходный текст программы приобретает черты 
по-настоящему отчуждаемого продукта, т.е. такого, 
который может быть легко передан коллеге, партнеру, 
подчиненному для использования и развития. Сам 
подход ООП известен достаточно давно, но 
“трудолюбивыми японцами 44 , первыми освоившими эту 
прогрессивную технологию, оказались специалисты 
Вогіапсі. В области объектно-ориентированных средств 
программирования у Вогіапсі серьезных конкурентов 
практически не оказалось. 

Для решения задач по обработке электронных таб- 
лиц корпорация Вогіапсі выпустила продукт (^иаНго 
Рго, который по своим функциональным характери- 
стикам превосходит самые свежие версии основных 
программ-конкурентов. Кроме того, (^иаНго эффек- 
тивно работает и на морально устаревших компьюте- 
рах невысокой производительности, даже совместимых 
с ІВМ РС/ХТ (внимание, советские руководители!). 
По числу установленных копий (^иаНго Рго конкури- 
рует только с продуктами давно захватившего лидер- 
ство на этом участке рынка семейства Шиз 1-2-3 
фирмы Шиз Оеѵеіоршепі. 


Во второй половине 80-х годов начало создаваться 
впечатление, что Вогіапсі обладает даром, сравнимым 
с прикосновением Мидаса: практически каждый про- 
граммный продукт, поставляемый фирмой, превраща- 
ется в золото — завоевывает ведущее место среди 
лучших изделий для своей категории. Так например, 
система управления базами данных Рагасіох фирмы 
Вогіапсі в 1990 году опередила по количеству продаж в 
США сверхпопулярный в прошлом продукт сіВАЗЕ 
корпорации АзМоп-Таіе. Технологическая победа в 
этом случае была увенчана и победой стратегической: 
в июле 1991 года было объявлено о слиянии Вогіапсі и 
АзМоп-ТаІе. Корпорация АзМоп-Таіе перестает суще- 
ствовать, а все права на ее продукты и разработки пе- 
редаются Вогіапсі. И это при том, что годовой оборот у 
Вогіапсі в 1990 финансовом году был меньше, чем у 
АзМоп-ТаІе! Коммерческая смелость и технологичес- 
кое новаторство перевесили арифметическое превос- 
ходство капитала. 

Таким образом, по всем стратегическим направле- 
ниям своего продвижения Вогіапсі сумел добиться либо 
подавляющего, либо заметного преимущества по 
отношению к продукции традиционных лидеров инду- 
стрии программного обеспечения. Количественное вы- 
ражение этого: теперь, в 1991 году, по суммарному 
обороту среди фирм — производителей программного 
обеспечения, ориентированного на ІВМ-совместимые 
персональные компьютеры, Вогіапсі (440 млн. долл.) 
уступает только МісгозоН (1.5 млрд, долл.) и Шиз 
(около 600 млн. долл.). За последние два года отмеча- 
ется двукратный рост прибыли Вогіапсі! Это успех, ко- 
торый может привести и к изменению порядка в 
“большой тройке“. Отметим, что корпорации Аиіосіезк 
и >ѴогдРегГес1, имеющие обороты свыше 
500 млн. долл., здесь нами не рассматриваются, ввиду 
специфичности предметной области, в которой они 
ведут разработки. 

Если же учесть присущие изделиям Вогіапсі исклю- 
чительно высокие качество, надежность и эстетич- 
ность, то сложившуюся ситуацию остается охаракте- 
ризовать словами: “Вогіапсі идет! 44 . 

Вогіапсі в СССР: воплотятся ли наши мечты? 

С первых же шагов на советском рынке корпорация 
Вогіапсі повела себя в присущем себе стиле: помимо 
высокого авторитета программных средств (ТигЬо Раз- 
саі, ТигЬо С++, Рагасіох, (^иаНго Рго, ОЬіесіѴізіоп) по- 
явились весомые дополнительные доводы для привле- 
чения покупателей к продукции фирмы. Эти доводы 
можно свести к тому, что можно назвать основными 
принципами маркетинговой политики Вогіапсі на со- 
ветском рынке. 

Принцип первый: торговый паритет. Продажа про- 
граммных средств ведется без ограничений по номен- 
клатуре — самые свежие версии, обладающие высшей 
технологической новизной даже на рынке США, пред- 
лагаются одновременно для всех потребителей в 
СССР. Залежалого товара у Вогіапсі не бывает! 
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Принцип второй: учет покупательной способности. 
Приобрести все программы Вогіапсі можно и за рубли, 
и за доллары, без “аннексий и контрибуций** в пользу 
долларовой номенклатуры. Рублевая цена оп-ре-де-ля- 
ет-ся в соответствии с покупательной спо-соб-но-с-тью 
молодого советского рынка, с учетом возможностей 
малых предприятий, частных фирм и индивидуалов. 
При этом, средний переводной коэффициент “по 
курсу Вогіапсі** близок к 10 рублям за один доллар 
цены продукта в США! 

Принцип третий: инвестиции в будущее. Зарабо- 
танные рубли расходуются на территории СССР, в 
первую очередь, на локализацию программных 
средств, проведение научно-технических мероприятий, 
рекламу, обучение и подготовку кадров. Так напри- 
мер, уже в 1991 году начались поставки наиболее по- 
пулярной СУБД Рагабох в “русифицированном** вари- 
анте. Разработка, предпринятая известным поставщи- 
ком адаптированных версий программного обеспече- 
ния зарубежных фирм, СП “Параграф** (г. Москва), 
позволяет отечественным пользователям работать с 
Рагабох на русском языке уже сегодня! Аналогичные 
работы завершаются для электронных таблиц ()ігаМго 
Рго. 

Принцип четвертый: льготы пользователям конку- 
рентных продуктов (сотреШіѵе ир^гаде). Для пользо- 
вателей программ-конкурентов объявлена “амнистия**: 
при переходе на соответствующий продукт Вогіапё 
они автоматически получают скидку до 60%, то есть, 
обладают теми же правами, что и зарегистрированные 
владельцы предыдущей версии программного средства 
Вогіапсі. 

Принцип пятый: союз с потребителем. Особое вни- 
мание в СССР корпорация Вогіапсі уделяет формиро- 
ванию и поддержке движения пользователей, созда- 
нию структур, поддерживающих и развивающих связи 
фирмы-производителя и потребителей программной 
продукции. 

Действительно, любой потребитель программной 
продукции (пользователь) склонен персонифицировать 
применяемые им средства. Во многом это связано с 
интеллектуализацией процессов обработки информа- 
ции на компьютере, что неотвратимо закладывает во 
взаимодействие “человек-программа** глубокую эмоци- 
ональную основу. По-видимому, это обстоятельство 
учитывается не только при проектировании диалого- 
вых средств Вогіапсі, которые славятся своей инту- 
итивностью и наглядностью, но и в определении так- 
тики фирмы в отношении связей с общественностью 
(РиЫіс геІаНопз). Так например, Вогіапсі проводит 
ежегодный международный семинар пользователей, на 
котором ведущие специалисты фирмы, начиная с са- 
мого Филиппа Кана, рассказывают о своих разработ- 


ках, выясняют тонкости восприятия их продукции со 
стороны пользователей, попросту — советуются с 
ними о перспективах развития отдельных пакетов про- 
грамм. 

Пользователи Вогіапсі в СССР, 
объединяйтесь! 

В 1991 году одним из наиболее очевидных успехов 
Вогіапсі в СССР из области связей с общественностью 
стало создание корпорацией совместно с инициатив- 
ной группой из числа московских программистов Ас- 
социации групп пользователей Вогіапсі в СССР 
(БорАГ). Активное участие в этом процессе приняли 
Международный компьютерный клуб (МКК) и первый 
дистрибьютор Вогіапсі в СССР — СП “Интерквадро**. 

Одна из неформальных целей создания Ассоци- 
ации — обеспечение советских программистов и поль- 
зователей дополнительной информацией о новейших 
технологиях в области программных продуктов, фор- 
мирование условий, позволяющих создавать конкурен- 
тоспособные программы мирового уровня с помощью 
инструментальных средств Вогіапсі. Деятельность Ас- 
социации направлена на достижение информацион- 
ного паритета советских и зарубежных программистов 
и подразумевает создание комфортной “информацион- 
ной среды** для ее членов. Ассоциация является не- 
прибыльным, некоммерческим общественным объеди- 
нением. Уникальность подхода Вогіапсі к работе с 
пользователями проявляется в том, что членами БорАГ 
могут стать не только зарегистрированные’, но и “не- 
легальные** пользователи программных средств 
Вогіапсі. 

Основные направления деятельности Ассоциации 
сближают ее с научно-техническими обществами, уже 
известными в СССР, как форма организации обще- 
ственной активности, в их числе: 

- научно-техническая пропаганда и популяризация 
инновационных подходов фирмы Вогіапсі к созданию 
и применению средств программного обеспечения, 
организация и проведение массовых мероприятий в 
сфере информатики; 

- содействие распространению в СССР и за рубежом 
новых программных продуктов, разработанных с по- 
мощью инструментальных средств Вогіапсі; 

- воспитание культуры легального использования про- 
граммных средств в СССР; 

- выявление и оказание содействия, включая бла- 
готворительное, перспективным, талантливым про- 
граммистам и коллективам, работающим со сред- 
ствами Вогіапсі; 

- организация и координация деятельности Групп 
Пользователей Вогіапсі в СССР, взаимодействие с за- 
рубежными Группами Пользователей. 

Только в первом полугодии 1991 года БорАГ и ее 
членами проведено 12 научно-технических семинаров 
с участием представителей корпорации Вогіапсі и эк- 
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спертое Ассоциации (в том числе, в Москве, Ленин- 
граде, Душанбе, Архангельске, Уфе, Казани, Севасто- 
поле). 

Все члены Ассоциации бесплатно получают пери- 
одический бюллетень "БорИС" ("Вогіапб — Иннова- 
ции Сегодня"). На его страницах публикуется новей- 
шая информация о достижениях Вогіапб, заметки об 
опыте применения продукции фирмы в СССР, пере- 
воды актуальных статей из зарубежных изданий. 

Для членов Ассоциации ежегодно проводится 
"Вогіаоб-лотерея". Корпорация Вогіапб бесплатно 
предоставляет свои новейшие продукты для проведе- 
ния лотереи. В рамках Лотереи-91 среди членов Бо- 
рАГ разыграны 30 экземпляров наиболее популярных 
продуктов фирмы Вогіапб: 

- ТигЬо Разсаі 6.0 Ргоіеззіопаі; 

- Рагабох 3.5; 

- (}иаиго Рго 2.0 . 

Ассоциация проводит ежегодный Всесоюзный кон- 
курс на лучшую разработку программных продуктов, 
выполненную средствами Вогіапб — "Вогіапб-Кон- 
тест“. Цель конкурса: внедрение международных кри- 
териев оценки качества программных средств, популя- 


ризация разработок фирмы, поиск новых идей и ори- 
гинальных подходов к использованию программного 
обеспечения Вогіапб, стимулирование и реклама раз- 
работок, которые используют продукцию Вогіапб. В 
конкурсе 1990-1991 года участвовали более 300 про- 
граммных разработок советских программистов со всей 
страны. На церемонии вручения наград, которая со- 
стоялась во время II Форума Международного компью- 
терного клуба (МКК) в Центре международной тор- 
говли в Москве, 41 лучшая работа была удостоена 
Дипломов Ассоциации групп пользователей Вогіапб и 
МКК. Все дипломанты получили в качестве призов 
разнообразные (и новейшие!) продукты Вогіапб, спе- 
циально выделенные для этого корпорацией, а один из 
авторов работы, занявшей первое место, сможет со- 
вершить поездку в Калифорнию для ознакомления с 
работой программистов Вогіапб. 

Ассоциация групп пользователей Вогіапб в СССР 
(БорАГ) приглашает и Вас стать ее членом! По вопро- 
сам о вступлении в Ассоциацию групп пользователей 
Вогіапб в СССР обращаться по адресу СП 
"Интерквадро" (см. ниже), тел. 150-92-01 (дем. зал). 

А Зотов 


И С П А 

КОНЕЧНОЭЛЕМЕ НТНЫЙ ПРОГРАММНЫЙ КОМПЛЕКС ДЛЯ ГОМ РС 

Интегрированная Система Прочностного Анализа (ИСПА) методом 
конечных элементов поможет Вам решить многие проблемы в области 
проектирования новых прочных и легких конструкций, модификации уже 
выпускающихся изделий, сократив затраты на изготовление и испытание 
опытных образцов. 

ИСПА работает на ШМ РС совместимых компьютерах в ОС М3 Б05 . 
и на рабочей станции БЕСТА в ОС ШПХ Зузіет V. 

ИСПА зарегистрирована в ЦИФ ГосФАП, 

ИСПА позволяет решать задачи: 

* линейной и нелинейной статики; 

* динамики; 

* стационарной и нестационарной теплопроводности; 

* термоупругопластичности. 

ИСПА это: 

* 10000 узлов, 10000 элементов и 25000 степеней свободы в 

одной модели на ШМ РС; ' 

* библиотека из более, чем 40 типов 1-но, 2-х и 3-х мерных 
конечных элементов и возможность их совместного использования; 

* интерактивная векторная и растровая графика; 

* встроенный генератор конечноэлементных сеток; 

* возможность создания пространственных моделей в системе АиіоСАБ; 

* связь с системой АціоСАБ; 

* дружественный оконный интерфейс; 

* полный комплект печатной документации; 

* бесплатное сопровождение в течение 1 года. 

ФИРМА ’МИШИД’ совместного советско-американского предприятия 'Эльба' 
адрес: 115580, г. Москва а/я 51, СП 'Эльба', фирма ’МИШИД’. 
телефон: 395-51-23. Факс: 398-42-15. 
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Р азвитие программного обеспечения 
связано с увеличением его сложности. 
При этом процесс разработки программ 
становится очень трудоемким, а их 
модификация и сопровождение — 
затруднительными. 


Введение в объектно- 
ориентированное 
программирование: 

язык ТигЬо Разсаі 



Первым шагом на пути преодоления постоянно рас- 
тущей сложности разработки программного обеспече- 
ния стала выработка принципов структурного про- 
граммирования и структурного подхода к проектиро- 
ванию программ. Модульность, структурный стиль и 
нисходящее проектирование позволили сократить 
сроки создания программ, упростить их отладку и со- 
провождение. Появились новые языки, которые пре- 
красно поддерживали требования структурного про- 
граммирования, а старые языки модифицировались до 
расширений, вписывающихся в принципы структур- 
ного программирования. 

Создание технологии объектно-ориентированного 
программирования стало вторым шагом на пути реше- 
ния указанных выше проблем. Поначалу ООП, при- 
сущее только таким специализированным языкам, как 
ЗтаЖаІк и Зітиіа, не получило широкого распростра- 
нения в обыденной практике. Ранние разработки в 
области ООП были тесно связаны с исследованиями в 
области искусственного интеллекта и моделирования. 

Поиск методов преодоления сложностей создания 
больших программных комплексов и их последующей 
модификации заставил переосмыслить принципы ООП 
для широкого применения. Использование этих прин- 
ципов, по образному выражению одного из редакторов 
журнала Вуіе, “превратило программирование из ле- 
востороннего — логического, в правостороннее — 


творческое “ (проводится аналогия с полушариями че- 
ловеческого мозга). Желание использовать принципы 
ООП в широкой практике привело к появлению объ- 
ектно-ориентированных расширений популярных язы- 
ков программирования. 

В настоящее время имеются объектно-ориентиро- 
ванные расширения таких языков программирования, 
как С, Разсаі и Узр. Для компьютеров, совместимых с 
ІВМ РС, ряд фирм выпускает компиляторы языка С++ 
( объектно-ориентированное расширение С), имеются 
компиляторы объектно-ориентированного расширения 
языка Разсаі — ТигЬо Разсаі фирмы Вогіапб и <}иіск 
Разсаі фирмы МісгозоН. Для программирования в 
среде АѴіпбо^з фирмой ТНе >ѴЪііеѵа1ег Сгоир разрабо- 
тан объектно-ориентированный язык Асіог. Выпущен 
ряд библиотек объектов, таких как ОЦесі Рго^еззіопаі 
фирмы ТигЬоРотѵег ЗоНчѵаге для языка ТигЬо Разсаі, 
С++ Тооіз фирмы Ко^ие >Ѵаѵе и Ілпс Іпіегіасе ЬіЬгагу 
фирмы 2іпс ЗоНѵаге для языка С++. 

Немного истории 

Впервые объектно-ориентированная техника про- 
граммирования была реализована более десяти лет на- 
зад для компьютеров фирмы Арріе, когда в 1980 году 
была выпущена объектно-ориентированная версия 
языка ЗтаШаІк. В 1985 году для компьютера Уза был 
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ВВЕДЕНИЕ В ОБЪЕКТНО-ОРИЕНТИРОВАННОЕ ПРОГРАММИРОВАНИЕ. ЯЗЫК ТЦКВО РАЗСАЬ 


создан язык программирования Сіазсаі. В нем был 
объединен синтаксис языка Разсаі с понятиями клас- 
сов и методов языка ЗтаШаІк. Этот язык, совместно с 
библиотекой классов Ьіза Тооікіі, использовался для 
разработки программного обеспечения компьютера 
Уза. 

В 1984 году группа разработчиков вместе с Никла- 
усом Виртом, автором языка Разсаі, начала работу по 
созданию языка ОЬ]ес1 Разсаі — объектно-ориентиро- 
ванного расширения языка Разсаі. Это расширение 
основывалось не на стандартном описании языка Раз- 
саі (150 Разсаі), и не на оригинальном языке Разсаі 
(Иенсен и Вирт), а являлось расширением синтаксиса 
языка Арріе Уза Разсаі, который, в свою очередь, уна- 
следовал много свойств языка ІІС80 Разсаі. Была 
также создана библиотека классов, названная МасАрр. 
Первая реализация этого проекта появилась в 1985 
году. 

В настоящее время 0Ь}ес1 Разсаі совместно с 
МасАрр широко используется для разработки приклад- 
ных программ для компьютеров МасіпІозН. 

ООП. Основные преимущества 

В чем же состоят преимущества ООП и что лежит в 
их основе? 

В действительности, при написании программ, даже 
объединяя отдельные данные в структуры и разумно 
разбивая программу на функциональные модули, про- 
граммист неминуемо сталкивается с большим количе- 
ством мелких деталей. 

ООП дает возможность отойти от мелких деталей 
программы (процедур и данных) и работать с ней, как 
с программной моделью объектов реального мира. При 
этом появляется возможность легкого перехода от 
одного уровня абстракции рассмотрения объекта (в де- 
талях) к другому (как единое целое). 

Другим преимуществом ООП является возможность 
использования ранее созданного программного обеспе- 
чения в процессе создания нового. При этом не требу- 
ется какой-либо переделки готового программного 
обеспечения и даже его перекомпиляции. 

Основу ООП составляет понятие объекта. Объект (в 
понимании ООП), объединяя в себе декларативную и 
процедурную части, моделирует некоторый концепту- 
альный или реальный объект окружающего мира. 
Программа, написанная в рамках ООП, представляет 
собой совокупность обменивающихся сообщениями 
объектов и моделирует некоторое реальное поведение 
предметов. Написание объектно-ориентированных 
программ облегчается тем, что программист создает 
программу, руководствуясь привычными понятиями 
той области, которую моделирует проектируемая про- 
грамма. 

Основа ООП — объекты 

Что такое объект и какие ему присущи свойства? 

Объект представляет собой совокупность данных и 


процедур, работающих с этими данными. Объект мо- 
жет моделировать как реальные явления, так и кон- 
цептуальные понятия, как например, классы структур 
данных: список, очередь, дерево, хэш-таблица и др. В 
программе объекты представляют собой переменные 
или константы. Переменная или константа типа дан- 
ных объект, называется экземпляром объекта. Доступ 
к полям данных объекта возможен только через про- 
цедуры-методы, определенные внутри этого объекта. 
Вызов процедуры, определенной внутри объекта, на- 
зывается передачей сообщения объекту. Объединение 
данных и процедур, работающих с этими данными в 
объекте, называется инкапсуляцией. Инкапсуляция, 
наряду со строгой типизацией, ранее присущая таким 
языкам программирования как Ада и Модула, обеспе- 
чивает защищенность полей данных объекта от не- 
предусмотренных модификаций, что в значительной 
мере повышает надежность программирования. 
Инкапсуляция гарантирует строго определенный, кон- 
тролируемый программистом набор свойств объекта. 

Другим важным свойством объектов является на- 
следование. Оно заключается в том, что вновь созда- 
ваемый объект может строиться на основе существу- 
ющего объекта-п редка. При этом он наследует и мо- 
жет использовать все поля данных и методы родитель- 
ского объекта. Объекты, связанные родственными 
отношениями, образуют иерархическую структуру 
(называемую иерархией объектов), которая может 
отражать иерархическую структуру моделируемого яв- 
ления. Иерархическая структура позволяет легко пере- 
ходить от одного уровня абстракции рассмотрения 
объекта (в деталях) до другого (как единое целое). 
Пример такой структуры показан на рисунке 1. 

АѴіпсІодѵ 



ІпІе^егРіеІб 

ВооІеапРіеІб 

— — Зігіп^РіеІсІ 
Рис.1. Иерархия объектов. 

На приведенном рисунке показана иерархия объек- 
тов, состоящая из базового объекта Окно (^іпёош), на 
основе которого строится объект Форма (Рогт). Объ- 
ект Поле (Ріеіё), построенный на базе объекта Форма, 
является предком для трех объектов ЦелоеПоле 
(ІпІе^егРіеІсі), ЛогическоеПоле (ВооІеапРіеШ), Стро- 
ковоеПоле (Зігіп^РіеІсі). 

Наследование дает возможность расширять уже со- 
зданные объекты, придавая им необходимые новые 
свойства. Доступ к динамически создаваемым объек- 
там одного семейства (иерархий) возможен посред- 
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ством совместимых по типам указателей. Поэтому, ча- 
сто, для обеспечения совместимости указателей, раз- 
личные объекты объединяют а одну иерархию, искус- 
ственно создавая единый для всех объект-предок, ко- 
торый называют абстрактным объектом. Абстрактный 
объект стоит в вершине иерархии и служит лишь для 
обеспечения совместимости типов указателей на объ- 
екты в иерархии. Абстрактный объект, как правило, 
не содержит в себе каких-либо полей данных и мето- 
дов. 

Объект-потомок может иметь методы с аналогич- 
ными именами, что и у объекта-п редка. В этом случае 
говорят, что объект-потомок переопределяет метод 
объекта-предка. Переопределение дает возможность 
передачи одного и того же сообщения экземплярам 
разных объектов. Возможность использования одина- 
ковых имен методов для различных объектов называ- 
ется полиморфизмом. 

Часто возникает необходимость использования в 
объекте-потомке ряда методов объекта-предка, 
имеющих обращения к методам, которые были 
переопределены у потомка. В этом случае возможно 
использование переопределенных методов, и такая 
возможность реализуется при помощи механизма вир- 
туальных методов. Это позволяет создавать новые 
программы с использованием уже созданных на уровне 
машинного кода. 

Язык ТигЬо Ра$саІ фирмы ВогіапЛ 

Каким образом свойства ООП реализованы в объ- 
ектно-ориентированном расширении языка ТигЬо Раз- 
саі фирмы Вогіапб? 

Для определения объекта введен новый описатель 
ОВ1ЕСТ. Он похож на описатель типа данных запись 
(ВЕСОМ}) с одним существенным дополнением — 
внутри него возможно определение методов (процедур 
и функций), оперирующих с полями данных этого 
объекта: 

Туре 

{Тип данных — объект} 

ОЬіесіШте = ОЬіесі 

{Описание различных полей данных объекта} 

ОаІаРіеІсШате : ОаІеТуре; 


{Заголовки методов (процедур и функций), 
оперирующих над полями данных объекта} 
ргосеЛиге МеіЬосШате (Рагатеіеге) ; 

Іипсйоп МеОюсШате : РипсііопКеІитТуре; 

епЛ; 

В определении объекта приводятся только заголовки 
методов. Процедуры и функции, которые реализуют 
данные методы, должны помещаться в любом месте 
раздела процедур или в секции ІМРЬЕМЕЫТАТЮЫ 
для объектов, определенных в единице компиляции 
ІЖІТ. Перед именем реализующей процедуры или 
функции должно стоять имя соответствующего типа 
объекта, отделенное разделителем (точкой): 


Ргосебиге ОЬіесіКате.МеіНосШаше; 

Ѵаг 

Ье§іп 

епф 

Определение экземпляра объекта производится в 
разделе переменных или констант путем указания 
имени экземпляра, от которого разделителем 
(двоеточием) отделяется имя типа объекта: 

Ѵаг 

ОЬіесйпвіапсе : ОЪіесіШте; 

Доступ к полям данных объекта возможен в любом 
месте программы, где распространяется определение 
объекта, указанием имени экземпляра объекта с отде- 
ленным от него разделителем (точкой) именем поля 
данных. Однако при этом происходит нарушение 
свойства инкапсуляции, поэтому пользоваться этой 
возможностью не рекомендуется: 

ОЬіесІІпзіапсе.ПаІаРіеІсДОате 

В случае необходимости доступ к полям данных и 
методам объекта, определенным в единице компиля- 
ции ІЖІТ, можно закрыть из других единиц компиля- 
ции (усиление свойства инкапсуляции). Для этого за- 
крываемая группа данных и методов размещается в 
конце описания объекта и перед ней указывается заре- 
зервированное слово Ргіѵаіе (при этом невозможно 
производить расширение свойств объекта, связанных с 
этими полями). 

Передача сообщения объекту (вызов метода) произ- 
водится указанием имени экземпляра объекта с после- 
дующим указанием черёз разделитель (точку) имени 
сообщения (метода). 

ОЪіесИпвіапсе.МеіЬосШате (Рагатеіеге) ; 

Как и в случае работы с записями, возможно 
использование оператора присоединения \Ѵі(Н для 
упрощения передачи нескольких сообщений экзем- 
пляру объекта, либо для обращения к нескольким по- 
лям данных экземпляра объекта. 

ЧѴііН ОЬіесіІпаіапсе Бо МеіНосШате (Рагатеіеге) ; 

\ѴіИі ОЬ}есіІп5Шпсе Во ... ЭаіаРіеІсШате ... 

Доступ к данным объекта внутри процедур, которые 
реализуют тот или иной метод, осуществляется путем 
указания имени соответствующего поля объекта. Ссы- 
латься на имя соответствующего экземпляра объекта 
или передавать его в качестве параметра не нужно, 
так как эта информация передается всем методам объ- 
екта через скрытый параметр 8е1Г. Этот параметр 
представляет собой не что иное, как указатель на 
экземпляр объекта и обеспечивает все потребности 
внутренней адресации. Иногда, в случае 
возникновения неоднозначности при обращении к 
переменным внутри процедур, возможно явное 
указание имени этого параметра перед именем поля 
данных соответствующего объекта: 

ЗДГ.БаіаРіеІсІІЧате 
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ВВЕДЕНИЕ В ОБЪЕКТНО-ОРИЕНТИРОВАННОЕ ПРОГРАММИРОВАНИЕ. ЯЗЫК ТЦКВО РАЗСАЬ 


То же самое относится и к вызовам других методов 
объекта внутри процедуры или функции, реализующей 
данный метод. 

Если предполагается, что методы, вызываемые 
внутри данного метода, могут быть переопределены в 
объектах-потомках и необходимо осуществлять обра- 
щение к переопределенным методам, то возникают 
следующие проблемы. В период генерации кода ком- 
пилятор не может сформировать корректные адресные 
ссылки на необходимый метод, так как заранее неиз- 
вестно, какая процедура будет реализовывать метод — 
собственная или одна из переопределенных в объек- 
тах-потомках. Процесс установки адресных ссылок в 
период компиляции/компоновки называют ранним 
связыванием. В случае обращения к переопределен- 
ным методам процесс установки адресных ссылок 
должен происходить во время выполнения программы 
(позднее связывание). Для указания компилятору 
того, какой тип связывания необходимо использовать, 
служит зарезервированное слово Ѵігіиаі, которое запи- 
сывается после заголовка метода при описании объ- 
екта: 

ргосебиге МейюсШате (Рагатеіеге) ; Ѵігіиаі; 

Если признак Ѵігіиаі присутствует, то будет 
использоваться позднее связывание, и соответству- 
ющий метод называется виртуальным. В противном 
случае осуществляется раннее связывание и метод на- 
зывается статическим. Если в заголовке метода появ- 
ляется признак Ѵігіиаі, то все методы в иерархии объ- 
ектов (у объектов-потомков) с аналогичными именами 
должны иметь тот же признак и аналогичный заголо- 
вок. В случае статических методов заголовок может 
меняться от потомка к потомку. 

Для обеспечения процесса позднего связывания в 
описании объекта необходимо использовать специаль- 
ный метод-конструктор, к которому необходимо обра- 
титься перед началом работы с каждым экземпляром 
объекта. Основная функция конструктора — связать 
конкретный экземпляр объекта с соответствующей его 
типу таблицей виртуальных методов объекта для 
обеспечения процесса позднего связывания. Таблица 
виртуальных методов содержит следующую информа- 
цию для каждого объекта: размер объекта и указатели 
на процедуры, реализующие виртуальные методы. 
Кроме того, в конструкторе возможно использование 
других предусмотренных программистом действий, не- 
обходимых для инициализации экземпляра объекта. 
Для метода-конструктора в его заголовке используется 
зарезервированное слово соп$1гис1ог: 

Соп5ілісіог Соп5(гисіог№те (Рагатеіеге) ; 

Для динамически размещаемых экземпляров объек- 
тов в процедуре Ыеѵ возможно указание вторым па- 
раметром обращение к конструктору: 

Ыеѵ(РоіпіегІп8Іапсе, СопзЬпсКиШте (...) ) ; 

Также возможно использование процедуры Ыеш как 
функции: 


Роіпіегіпаіапсе : = №*(ТуреКате, СопаЬчісІогКатеО); 

Для корректного (в случае использования меха- 
низма совместимых по типу указателей на объект) 
освобождения памяти, занятой динамически разме- 
щенным экземпляром объекта, возможно использова- 
ние специального метода-деструктора. Помимо осво- 
бождения памяти, в деструкторе можно предусмотреть 
любые действия, связанные с завершением работы с 
объектом и освобождением памяти, занятой динами- 
ческими полями данных объекта. Для метода-деструк- 
тора в его заголовке используется зарезервированное 
слово безігисіог: 

Безігисіог ОезІгисіогШте (Рагатеіеге); 

Компилятор автоматически подставляет в конструк- 
тор и деструктор необходимые служебные действия, 
поэтому, если нет необходимости использования ка- 
ких-либо дополнительных действий по инициализации 
и деинициализации объекта, тела соответствующих 
процедур должны быть пустыми. В процедуре Оі$р05е 
для экземпляра динамического объекта возможно 
использование деструктора: 

І>І5ро5е(РоіпіегІп8(апсе, Эе$1гис1огКате(...)); 

В дальнейшем мы более подробно опишем различия 
между статическими и виртуальными методами, рас- 
пределение памяти под объекты, использование вирту- 
альных методов и динамических объектов. 

Д. Рогаткин 
. А. Федоров 


Агентство 
КомпьютерПресс 
продолжает принимать 
заявки на публикацию 
рекламных объявлений 


Широкий круг читателей, 
всесоюзное распространение 
и большой тираж 
нашего ежемесячного журнала 
делают рекламу 
в КомпьютерПресс 
эффективной. 


Наш адрес: 113093 Москва , а/я 37 

Факс: (095) 200-22-89 

Е-таН: ро$1та$1ег@срге$$.т$к.5и 


КомпьютерПресс 1Г91 





СТРАНА ПО ИМЕНИ ВОКЬАОД 


49 


Приведенный ниже словарь терминов базируется на объектно-ориентиро- 
ванном расширении языка Разсаі — ТигЪо Разсаі 6.0 фирмы Вогіапй, но 
включает при этом распространенные термины , присущие другим языкам. 

Термины объектно-ориентированного программирования 


Абстрактный объект (АЬзігасі оЬіесі) — 
основным назначением абстрактного объекта является 
создание базового объекта, который затем может быть 
наследован другими объектами. Экземпляры абстракт- 
ного объекта никогда не создаются. Использование аб- 
страктных объектов позволяет связать несколько объ- 
ектов в одну иерархию объектов. Синоним термина в 
языке ЗтаІНаІк — абстрактный суперкласс (аЪзІгасІ 
зирегсіазз). 

Библиотека классов (С1а$$ ЫЬгагу) — набор 
готовых объектов общего назначения. Примером биб- 
лиотеки классов для языков ТигЬо Разсаі и (^шск Раз- 
саі является продукт фирмы ТигЬо Ро^ег Зо^Ьѵаге — 
ОЬ}ес1 РгоГеззіопаІ. 

Виртуальный метод (ѴігШаІ тейюсі) — метод, 
адрес которого известен только в момент выполнения 
программы. Когда происходит вызов виртуального ме- 
тода, его адрес берется из таблицы виртуальных ме- 
тодов. Это называется непрямым вызовом. В языке 
ТигЬо Разсаі виртуальный метод отмечается ключевым 
словом Ѵігіиаі. 

Дерево классов (С1а$$ ігее) — термин языка 
Асіог, синоним термина иерархия объектов. 

Деструктор ( Ое&ігисіог ) — специальная проце- 
дура для высвобождения памяти, занятой объектом. 
Если по завершении работы с объектом (перед его 
удалением из памяти) необходимо выполнение каких- 
либо специальных действий, они должны быть выпол- 
нены внутри деструктора. Эта специальная процедура 
может быть вызвана в качестве параметра стандартной 
процедуры Бізрозе (ТигЬо Разсаі). Деструктор объяв- 
ляется использованием зарезервированного слова <1е- 
зігисіог: 

безігисіог Попе; 

Иерархия классов (С1а$5 НіегагсЬу) — термин 
языка ЗтаШаІк, синоним термина языка ТигЬо Разсаі 
иерархия объектов и термина языка Асіог дерево 
классов. Иерархия классов позволяет создавать 
классы-потомки существующих классов таким обра- 
зом, что классы-потомки наследуют все данные и ме- 
тоды классов-предков. Иерархия классов создается 
объявлением абстрактного объекта в вершине иерар- 
хии и присвоением этому абстрактному объекту 
общего указателя на код и данные всей иерархии. 

Инкапсуляция (Іпсарзиіаііоп) — объединение в 
типе данных объект полей данных и методов 
(процедур и функций), работающих с этими данными. 

Класс (С1а$$) — синоним термина языка ТигЬо 
Разсаі тир данных объект. 


Конструктор (Соп$*гисіог) — специальная про- 
цедура, инициализирующая экземпляр объекта, со- 
держащий виртуальные методы, путем установки 
связи между экземпляром объекта и таблицей вирту- 
альных методов. Эта специальная процедура может 
быть вызвана в качестве параметра стандартной про- 
цедуры Ые^. В ТигЬо Разсаі конструктор объявляется 
использованием зарезервированного слова сопзігисіог: 

сопзігисіог Іпіі; 

Метод (Мейюй) — процедура или функция, 
определенная внутри объекта для работы с данными 
объекта. Методу доступны данные объекта без явной 
передачи их в качестве параметров. Возможно насле- 
дование методов. Методы могут быть статическими и 
виртуальными. Для виртуальных объектов существуют 
два специальных метода — конструктор и деструк- 
тор. 

Множественное наследование (Миіііріе ІпЬег- 
ііапсе) — наличие у объекта нескольких родителей. 

Наследование (ІпНегііапсе) — процесс получе- 
ния данных и методов от объекта-предка. Возможно 
многоуровневое наследование. 

Объект (ОЬ]ес() — тип данных объект. Совокуп- 
ность данных и процедур — операций над этими дан- 
ными (называемых методами). Дополнительно объ- 
екты могут наследовать методы и данные объектов- 
предков. Термин объект является синонимом термина 
класс (сіазз) языка С++. 

Объекты-контейнеры (Сотаіпег ОЬіесіз) — 
объекты, способные хранить в себе другие объекты. 
Например: стек, очередь, дерево, динамический мас- 
сив, хэш-таблица и другие подобные структуры. 

Объект-потомок фезсепбат оЬіесО — объект, 
наследующий методы и данные от объекта-предка. 

Ьосаііоп = ОЬ]есЦ {« — Объект-предок } 

{Данные объекта и методы} 

епф 

Роіпі = ОЬіесЦЬосапощ ; {« — Объект-потомок} 

{Данные объекта и методы} 

епд; 

Объект-предок (Апсезіог оЬіесі) — объект, ме- 
тоды и данные которого наследует объект-потомок. 

Параметр 8еН (8еК Рагашеіег) — формальный 
параметр, передаваемый каждому методу. Содержит 
указатель на конкретный экземпляр объекта. 
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Переопределение (Оѵеггійе) — процесс создания 
у объекта-потомка новых методов с теми же именами, 
что и у объекта-п редка, но с новыми функциями. Это 
делает возможным расширение объектов. В языке 
ТигЬо Разсаі 6.0 методы переопределяются прямым со- 
зданием новых методов с теми же именами. В (}иіск- 
Разсаі ключевое слово ОѴЕИКШЕ должно быть вклю- 
чено после описания переопределенного метода: 

Туре 

Роіпі : ОЩесІ (Ьосаііоп) 

Соіог : Іліедег; 

Ргосесіиге ЗНоѵ, ОѴЕККГОЕ; 

Ршісбоп СеіСоІог : Іпіеяег; 

Ргосесіиге 8еіСо1ог(№ѵСо1ог : Іпіе^ег) ; 

Епд; 

Передача сообщения (Мез$а§е ра5$іп§) — вы- 
зов метода для конкретного экземпляра объекта. Отли- 
чие сообщения от метода в том, что одно и то же со- 
общение может вызывать разные методы. Пример: 

СігсІе.Пгаѵ, 

КесШп^е.Игаш; 

РіЯигев'.Огачг, 


Санкт-Петербургский филиал совместного 
советско-американского предприятия 

ШТЕКЫАТІОЫАІ. МАПКЕТІЫС & 
СОЫ8Ш.ТШС СОПРОВАТІОЫ 

предлагает программные продухты для 
компьютеров, совместимых с ІВМ ре 

1.20 — пакет создания интер- 
фейса пользователя для Мб С, ТигЬо С, 
ТигЬо С++, ТигЬо Разсаі и М8 Гогігап-77, 
включая полноэкранный редактор окон, 
генератор исходных текстов программ и 
библиотеки поддержки; 

2<ЖБ 2.0 — защита от несанкциониро- 
ванного копирования выполняемых и тек- 
стовых файлов на жестких и гибких дис- 
ках; 

СК088 2.0 — кросс-система подготовки 
ЖЖ 8 Д ля микроконтроллера 

ѴОС 3.1 — пакет перевода текстовых фай- 
лов с английского на русский и наоборот; 
К8_8ТАТ — статистический анализ и мо- 
делирование; 

РА8Т-РКО — инструментальные средства 
для системы СЫРРЁК; 

РЬАКЕТ 1.3 — быстрая печать платеж- 
ных поручений; 

ОГРІСЕ — бухгалтерский учет государст- 
венных и коммерческих предприятий; 
ОШБЕ8 — электронные справочники 
(Ыогіоп Оиі(1е8) на русском языке по 
СУБД, языкам программирования, тексто- 
вым редакторам, сервисным программам. 

Наш адрес: 190000 Санкт-Петербург , 
бульвар Профсоюзов , 4-13. 

Телефоны: (812) 311-64-61 , 311-61-30 
Факс: (812) 311-78-22 


Подкласс (8иЬс1а$$) — как и термин супер- 
класс, используется в языке ЗтаШаІк. Подкласс — это 
класс-потомок. Другими словами, если класс В насле- 
дует из класса А, то класс В является подклассом 
класса А. 

Позднее связывание (Ьа*е Ыпбіп§) — ситуация, 
при которой адрес вызываемого метода неизвестен до 
момента выполнения программы. Адресация разреша- 
ется путем использования таблиц виртуальных мето- 
дов с адресами методов. Также возможно раннее свя- 
зывание. 

Полиморфизм (Роіушогрііізт) — возможность 
использования методов с одинаковыми именами для 
работы с различными типами данных. 

Раннее связывание (ЕагІу Ьіп<ііп§) — ситуация, 
при которой адрес вызываемого метода известен в мо- 
мент компиляции/компоновки. Также возможно 
позднее связывание. 

Расширяемость (ЕхіепсІіЬіІку) — благодаря 
свойству наследования, обг^кты могут быть расши- 
рены новыми функциями и/или полями данных. Но- 
вый метод изменяет или расширяет функции унасле- 
дованного метода и заменяет его в объекте-потомке. 
Возможно также добавление ряда новых методов к 
уже существующим. 

Связывание (Віпйіп^) — процесс, в результате 
которого вызывающая подпрограмма получает адрес 
вызываемой подпрограммы. Возможно раннее и позд- 
нее связывание. 

Статический метод (Зіаііс теГпос!) — метод, 
вызываемый с использованием раннего связывания 
(адрес которого известен в момент компиля- 
ции/компоновки). По умолчанию все метода ТигЬо 
Разсаі являются статическими 

Суперкласс (8ирегсЬ5$) — в иерархии объек- 
тов каждый класс имеет только одного непосредствен- 
ного предка, называемого "предком" или 
"суперклассом". Этот терм к -(пользуется в языке 
ВтаШаІк. 

Таблица виртуальных методов (Ѵігіиаі шеШоб 
іаЫе) — таблица, хранчмля в сегменте данных. Эта 
таблица создается для каждого объекта, имеющего 
виртуальные методы. В -этой таблице хранятся адреса 
описанных в объекте виртуальных методов. 

Экземпляр (ІП5&псе) — строго говоря, термин 
экземпляр не является специфическим для объектно- 
ориентированного программирования, но в связи с по- 
следним используется наиболее часто. Экземпляр — 
это объявленная переменная типа объект. Например, 
если имеется выражение Ѵаг А : Ьосаііоп, можно ска- 
зать, что А является экземпляром типа Ьосаііоп: 

Ьосаііоп = ОЬ]ес1; 

(Данные объекта и методы} 

еші; 

Ѵаг А : Ьосаііоп; 
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Эта статья посвящена новому 
компилятору фирмы Вогіапй — ТигЬо 
Разсаі /ог Шпйот, который позволяет 
создавать объектно-ориентированные 
программы в среде Місгозор Шпдот. 


ТЫКВО РА5СМ 
РОК Ѵѵ'ІЫООѴ/5 


Не успели отгреметь фанфары по поводу компиля- 
тора ТигЬо Разсаі 6.0 с прекрасной оболочкой ТигЬо 
Ѵізіоп, а на улице ТигЬо Разсаі очередной праздник: 
фирма Вогіапсі выпустила компилятор для создания 
\Ѵіпс10АѴ5-программ — ТигЬо Разсаі для ^ііккжз 
(ТР >Ѵ). 

До настоящего времени для создания Ѵ/Чпбодѵз-про- 
грамм в основном использовался язык С (ряд приклад- 
ных программ создается на объектно-ориентированном 
языке Асіог фирмы \ѴНі1ечѵа1ег) и большая часть раз- 
работки велась преимущественно в среде Э08 с 
использованием ряда пакетных утилит. 

ТР\Ѵ — первый компилятор языка программирова- 
ния 3-го поколения, полностью работающий в среде 
ДѴіікіоаѵз. В состав ТР>Ѵ включены все средства, необ- 
ходимые для разработки ХѴіпбо^ѵз-программ, так что 
использование МісгозоН 8ЭК не требуется. Необхо- 
димо отметить, что ТР^Ѵ предназначен только для со- 
здания ѴЯпбодѵз-программ, для создания 008-про- 
грамм необходимо использовать компилятор ТигЬо 
Разсаі 6.0. Ниже приведены основные различия между 
этими двумя продуктами: 


ТР\Ѵ 

ТигЬо Разсаі 6.0 

Разработка программ 
только для ^Ѵіпсктз 

Разработка программ 
только для 008 

Среда \Ѵіп(кпѵ5 

Среда БОЗ 

Объектно-ориентиро- 
ванная библиотека 
ОЬіесОУіпсіо^з 

Объектно-ориентиро- 
ванная библиотека 
ТигЬо Ѵізіоп 

Только одна версия 

Стандартная и “профес- 
сиональная" версии 


Интегрированная среда 


Интегрированная среда разработчика (ИСР), рабо- 
тающая в среде АѴіпйоаѵз — наиболее выразительная 
часть нового компилятора. Весь процесс создания 
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>ѴіпсІодѵ5-программы: ввод исходного текста, редакти- 
рование, компиляция, выполнение и отладка происхо- 
дит непосредственно в среде >Ѵіпдо>ѵ5. Возможно 
одновременное открытие до 32 окон, которые могут 
быть произвольным образом расположены в рабочей 
области. Каждое окно может быть распахнуто или 
превращено в иконку. Строчное меню содержит прак- 
тически те же команды, что и меню ИСР компилятора 
ТигЬо Разсаі 6.0. Редактор поддерживает отмену и по- 
втор операций. 

Редактор может работать в двух режимах: режиме, 
совместимом с другими >Ѵіпсклѵз-программами и под- 
держивающем набор команд стандарта ЗАА/СІІА, и в 
“альтернативном" режиме, поддерживающем набор 
совместимых с АѴогсІзІаг команд. В этом режиме воз- 
можно создание собственных комбинаций клавиш с 
помощью специального макрокомпилятора. 

Изменение ИСР наложило свой отпечаток на ряд 
команд. Например, нажатие клавиш выполнения опе- 
рации поиска/замены приводит к появлению блока 
диалога, в котором необходимо указать ряд парамет- 
ров. Комбинации клавиш Л КВ и Л КК позволяют выде- 
лить блок, но любое перемещение указателя отменяет 
выделение блока; таким образом для того, чтобы пе- 
реместить блок, вместо команды Л КѴ теперь необхо- 
димо пользоваться областью СНрЬоагй >Ѵігк1о\ѵз. 

Благодаря тому, что ИСР работает в среде >Ѵітіо^ѵ5, 
возможно непосредственное выполнение созданной 
программы из среды — используя, как и в предыду- 
щих версиях, команду Кип. 

Расширения языка 

Похоже, стало уже традицией в каждой новой вер- 
сии вносить ряд изменений в синтаксис языка. В дан- 
ной версии фирма Вогіапд предприняла еще один шаг 
в сторону превращения языка Разсаі в язык С — была 
введена поддержка А5СІ2-строк. Это нововведение 
объясняется тем, что АРІ АѴіпсіочѵз использует именно 
такие строки. 

В ТР>Ѵ определен новый тип данных РСЬаг как 
Л СЬаг (указатель на символ) и имеется возможность 
присвоения этому типу данных адреса строки: 

ѵаг 

СНагРіг : РСЬаг; 

СНагРй* : = Неііо, ШогМ Г; 

Помимо этого, имеется возможность ссылки на кон- 
кретный элемент такой конструкции, например, на 
третий, как на СНагР1г[3]. Также возможно объедине- 
ние строк и удаление подстрок, определенных через 
указатели. Компилятор выполняет целочисленное 
сравнение смещений этих указателей, рассматривая 
их как беззнаковые слова. Компилятор не поддержи- 
вает проверки выхода за пределы диапазона (гапде- 
сЬескіод) при работе с этими строками. Такая про- 
верка должна выполняться программистом. В состав 
ТР>Ѵ входит модуль Зігіп^з, включающий в себя фун- 


кции для вычисления длины строки, копирования 
строк и подстрок, объединения строк, сравнения 
строк, преобразования строк и т.п. 

С целью сокращения размера занимаемой памяти 
при использовании технологии объектно-ориентиро- 
ванного программирования в ТР>Ѵ введена поддержка 
таблиц динамических методов (ТДМ). Подробное опи- 
сание этого расширения требует отдельной статьи, 
здесь же лишь укажем, что занимаемая таблицами 
виртуальных методов память существенно сокраща- 
ется, особенно при использовании больших иерархий 
объектов. 

Введен ряд новых директив компилятора: 

- директива $С позволяет управлять атрибутами сег- 
мента кода; 

- директива $К предназначена для подключения ре- 
сурсов (иконок, меню, блоков диалога и т.п.) к при- 
кладной программе; 

- директива управляет генерацией про- 

лога/эпилога, специфичного для АѴіпсІочѵз при 
вызове подпрограмм. 

Также расширен синтаксис языка для поддержки 
создания и использования динамических библиотек 
ФІХ) и динамических виртуальных методов. 

Поддержка 

динамических библиотек 

ЛѴіпсіоіѵз позволяет прикладным программам 
использовать отдельные модули кода, называемые ди- 
намическими библиотеками ФІХ), которые динами- 
чески компонуются к программе загрузчиком АѴіпсІодѵз. 
Каждая такая библиотека может содержать большое 
количество функций. ТР>Ѵ позволяет вызывать под- 
программы, расположенные в БІХ и создавать соб- 
ственные динамические библиотеки. Каждая подпро- 
грамма в О IX имеет название и индекс. Вызов 
подпрограммы может производиться как по названию 
(что происходит по умолчанию), так и по индексу. 

Для доступа к ЭІХ (импорта) введена специальная 
директива ехіегпаі: 

ргосебиге ІшрогФІХ; ехіегааі ОІХІЧате'; 

Создание Э IX- модуля заключается в описании про- 
цедур и функций библиотеки: 

ИЬгагу МуБІХ; 

{реализация процедуры и функций библиотеки} 

{ехрогіз} 

Ъе#п 

епб. 

Средство для создания ресурсов 

Помимо выполняемого кода, >Ѵіпсіо\ѵз-программа 
может включать в себя ресурсы — иконки, меню, 
блоки диалога, курсоры, битовые изображения и т.п., 
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для визуального создания которых в состав ТРАѴ 
включено средство — >ѴНИе^аіег Кезоигсе ТооІкИ 
ОѴЯТ). >ѴКТ является альтернативой Оіаіоз Едііог и 
другим утилитам для работы с ресурсами, включенным 
в 8РК. АѴЯТ на самом деле является набором редакто- 
ров, объединенных единым интерфейсом и позволя- 
ющих редактировать блоки диалога, иконки, битовые 
изображения, меню, курсоры и другие ресурсы. По- 
мимо возможности непосредственной работы с тексто- 
выми файлами ресурсов, >ѴКТ позволяет извлекать ре- 
сурсы из файлов типа КЕ8, ЕХЕ и ОІХ. 

ТигЬо ИеЪи^ег 
для ѴѴіпскжз (ТТ>\Ѵ) 

При необходимости отладки программ возможен 
вызов отладчика из ИСР. Эта возможность является 
новинкой, так как раньше фирма поставляла два 
отладчика: встроенный в среду и внешний. При 
вызове отладчика (команда ОеЬи&&ег меню Кип) 
экран переключается в текстовый режим и появляется 
отладчик, внешне напоминающий отладчик, 
используемый в .среде 008. В ТЭАѴ добавлен ряд 
возможностей для отладки АѴіпскиѵз- программ: 
просмотр >Ѵіпдотѵз-сорбщений, локальной и глобальной 
“кучи“, просмотр модулей, загруженных >Ѵіпдодѵз, и 
отладка динамических библиотек ФЬЬ). Обладая, с 
одной стороны, удобством при отладке >Ѵіпдо\ѵ5- 
программ, ТО>Ѵ не позволяет параллельно выполнять 
никаких >Ѵіпдо\ѵз-программ и даже не позволяет 
переключать задачи клавишами Сігі-Езс и АИ-ТаЬ. 

Разработка программ 

ТР\Ѵ предоставляет возможность создавать >Ѵіп- 
до\ѵз- программы тремя способами, в зависимости от 
требований к программе и опыта разработчика. При 
необходимости быстрой переделки программ, работав- 
ших в текстовом режиме в среде 008, можно исполь- 
зовать модуль ^іпСКТ. Этот модуль обрабатывает вы- 
зовы процедур Кеасііп, ^гИеІп и СоІоХѴ. Модуль не 
поддерживает меню, и для того, чтобы закрыть окно 
по окончании работы программы (если оно не закрыто 
пользователем), требуется вызов специальной проце- 
дуры ЧѴіпСКТБопе. Ставший классическим пример с 
выводом сообщения “Неііо, чѵогід!" в данном случае 
выглядит следующим образом: 

рго$гат >ѴіпНе11о; 
изез >ѴіпСЛ; 

Ве^іп 

>Ѵгііе1п ( Неііо, АѴогІдГ); 

Епд. 

Отметим, что наличие только одной строки — изез 
ЧѴіпСгІ — делает программу, работающую в 008 в 
текстовом режиме, >Ѵіпсклѵ5-программой. 

Для создания более профессиональных прикладных 
программ в состав ТР>Ѵ входит объектно-ориентиро- 
ванная библиотека классов ОЪіесПѴіпдо\ѵз. Интер- 


фейс с этой библиотекой более простой, чем с ТигЬо- 
Ѵізіоп, и она также проще в изучении и использова- 
нии. Основной класс библиотеки — класс ТАррІіса- 
ііоп, наследник которого является текущей приклад- 
ной программой. Программа с использованием ОЬ- 
]есЯѴіпдочѵз может выглядеть следующим образом: 

рго^гат ѴПпНеНо; 
изез ѴГОЪ]ес1з; 

*Уре 

ТОето « оЬ]есі (ТАррІісадоп) 
ргосесіиге ІпііМаіпДУіпдоѵ; ѵітіаі; 
епд; 

ѵаг 

АѴіпОешо : ТОето; 

ргоседиге ТОето.ІпШаіпѴГтдоѵ, 

Ъе$іп 

Маіп^іпдоѵѵ : « Кеш(Р>Ѵіпд(ж,ІпШпі1,'НеиоГ)); 
епд; 

Ве&іп 

АѴІпЛето.ІпіК"): 

ЛѴіпОето.Кип; 

ѴПпОето.Оопе; 

Епд. 

Как видно из приведенного примера, у ОЪіесіѴЯп- 
до\ѵ5 много общего с ТигЬо Ѵізіоп. Ряд классов и 
общая организация похожи, но перенос созданных 
программ из 008-среды в >Ѵіпдочѵз-среду требует су- 
щественной переделки. 

Если же есть необходимость в написании программ, 
использующих вызовы АУіпдоіѵз-функций напрямую 
(например, для переделки программ, написанных на 
языке С с использованием МісгозоН 8ЭК), в состав 
ТРЛѴ включен модуль ^іпРгосз. Полный пример про- 
граммы, использующей >Ѵіпдочѵз АРІ, занимает много 
места. Ниже показан ее фрагмент — процедура ^Ѵіп- 
Маіп: 

ргоседиге ѴГтМаія; 

Ѵаг 

ѴГіпдоѵ? : ШѴпд; 

Мезза^е: ТМз$; 

Сопзі 

ѴГтдомСІазз : ТЛѴпдСІазз = ( 

81у1е : 0; 

1рГп\ѴпдРгос : @\ѴіпдоѵѵРгос; 
сЬСІзЕхіга : 0; 
сЬѴѴпдЕхІга : 0; 

НІпзіапсе : 0; 

Ысоп : 0; 

НСигзог : 0; 

НЬгВаск^гоипд : 0; 

1рз2Мепи№те : АррШте; 

ІрзгСІаззКате : АррКате; 

) 

Ье^іп 

И НРгеѵІпзі = 0 іНеп 
Ье^іп 

У/іпдсіѵСІазз.МпзІапсе : = НІпзіапсе; 

\Ѵіпдо\ѵС1азз.Мсоп : = 

Ьоадісоп (0,іді_Арр1ісаііоп) ; 

\Ѵтдо\ѵС1азз. НСигзог : = 

ЬоадСигзог (0,ідс_Аггоѵ) ; 
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ѴГіпсІо\ѵС1а$$.НЪгВаск8Гоип(І : = 
Сеі8іоскОЪіес!(\гіШе_Вги$Н) ; 
іі по! Ке^і8ІегС1а880ѴіпсІо\ѵС1а88) іЬеп 
На И (255) ; 

епсі; 

\Ѵіпсіо\ѵ : = Сгеа!е\Ѵш(іош( 

АррКаше, 

Неііо, \Ѵог1<Г, 

™$_Оѵег1арресПѴіп(Іо\ѵ, 

сш_ІІ$еПеІаи1і, 

сш_и$еОеГаи1і, 

оѵ_ІІ8еОеГаи1І, 

О, 

О, 

Ніпзіапсе, 
піі) ; 

$Но\ѵАѴіпсіоѵОѴіп(іош, СпкІЗНст); 
ІІрс1а1е>Ѵіп(Іо\ѵОѴт<Іо*0 ; 
ѵѵНіІе СіеМе88а^е(Ме88а^е,0,0,0) сіо 
Ье^іп 

Тгап$1аІеМе$$аяе (Меаза^е) ; 
ОіхраісЬМеааа^е (Мезаа^е) ; 
епсі; 

НаІКМеззаяе.ѵРагаш) ; 
епсі; 

Ье^іп 

\ѴіпМаіп; 

епсі. 


Заключение 

Снижение трудоемкости разработки прикладных 
Ѵ/тсІолѵз-программ на ТР\Ѵ по отношению к С можно 
сравнить с соотношением сложности создания Б08- 
программ на языках высокого уровня и на ассемблере. 
Использование объектно-ориентированного подхода и 
библиотеки ОЪ]ес(\Ѵіпс1оіѵз существенно сокращает 
время, требуемое на разработку АѴіпсіо^ѵз-программ. 

Можно выделить несколько категорий 
пользователей ТРАѴ: 

- программисты, использующие ТигЬо Разсаі и жела- 
ющие создавать >Уіпсіоііѵ5-программы; 

- программисты, ранее использовавшие ТигЬо Разсаі и 
перешедшие на МісгозоН С для написания АѴіпсІодѵз- 
программ; 

- программисты, не удовлетворенные разработкой 
АѴіпсІоіѵз-программ с использованием МісгозоІі 5ЮК; 

- программисты, использующие средства разработки 
типа ТооІЪоок, не удовлетворенные низкой скоро- 
стью работы этих средств; 

- программисты, которым необходимо перенести про- 
граммы, созданные с использованием ТигЬо Ѵізіоп, в 
среду МісгозоН АѴіпсіоаѵз; 

- программисты, использующие язык РАЬСУБД Рага- 
бох, желающие создавать \Ѵіп<іо\ѵ5-программы, 
используя библиотеку Рагабох Еп&іпе 2.0. 


Л, Федоров 


Фирма ІВМ выпустила новую 
серию персональных компьюте- 
ров цля мультимедиа. Эти изде- 
лия будут продаваться под мар- 
кой “ІЛіітесІіа “ ІВМ Р8/2 ІЛіі- 
теёіа Мосіеі М57 8ЬС — это 
первый компьютер Регзопаі 8уз- 
1ет/2 (Р8/2) со встроенными 
устройствами для мультимедиа и 
“самым быстрым 386 процессо- 
ром". Продажа системы начнет- 
ся в марте 1992 г. Стоить она 
будет 5995 долларов. 

ІВМ Р8/2 АсІіопМеФа II — 
набор адаптеров для ввода и вы- 
вода цифрового видео- и аудио- 
сигналов. Устройство будет про- 
даваться по цене 1995 долларов 
в двух версиях — для Місго 
СНаппеІ АгсНИесІиге (МСА) и 
для Іпсіизігу 8іапс1аг(1 АгсЬііес- 
іиге (І8А). Дополнительно мож- 
но приобрести пакет улучшения 
качества введенного изображе- 
ния и программную систему для 
разработчиков за 890 и 510 дол- 
ларов соответственно. 


ІВМ Р8/2 ТѴ — устройство, 
которое будет состоять из видео- 
адаптера, тюнера, динамика и 
программ. Начнет продаваться 
за 495 долларов с 27 марта 
1992 г. 

ІВМ Р8/2 ТѴ позволяет одно- 
временно смотреть до 70 телеви- 
зионных программ на экране 
Р8/2, а новый адаптер 
Р-Соиріег позволяет передавать 
живое изображение через ло- 
кальную сеть Токеп Яіп^. 

ІВМ Р8/2 ТоисЬ8е1есі — сен- 
сорный экран. 12-дюймовая мо- 
дель стоит 670, а 19-дюймо- 
вая — 850 долларов. 

И еще ІВМ обещает выпус- 
тить учебный мультимедиа-диск 
для безработных. 

Ме\ ѵ$Ьуіез 1Яе\ѵз МеЬѵогк, 
18 ОсіоЪег 1991 

Фирма Беа^аіе ТесЬпоІо^у 
объявила о крупных финансовых 
убытках — 47.8 миллиона дол- 


ларов — в этом квартале. Объем 
продаж, равный 620 миллионам 
долларов, остался практически 
на уровне предыдущего кварта- 
ла. Официально убытки относят 
на счет реорганизации компа- 
нии. 

Как сообщает ПРІ, Дэвид 
Митчел, сооснователь фирмы, 
неожиданно подал в отставку 
20 сентября после 12 лет работы 
в фирме. 

При попытке реорганизации с 
фирмы было уволено 1200 чело- 
век в июле (18% персонала), и 
еще 450 человек в августе. 

Как и фирма Соппег 
Регііегіаіз, также объявившая об 
увольнениях, 8еа^а(е объясняет 
все свои проблемы экономичес- 
ким спадом, хотя, видимо, война 
цен между 8еа&а1е, Соппег и 
С^иапШт также сыграла свою 
роль. 

Ыеу^зЪуіез Мем *8 ЫеЬ\югк у 
18 ОсіоЪег 1991 
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При анализе прикладного программного обеспечения принято 
выделять электронные таблицы, текстовые редакторы, 
программные средства связи, системы управления базами 
данных и графические редакторы. Попытка отнести ОЬ]'ес( 
ѴЫоп к одному из этих классов вызовет некоторое 
затруднение, так как он является представителем 
интегрированного программного продукта, одной из 
характерных черт которого является 
многофункциональность. 


ОЬіесіѴІ5Іоп: 
первые впечатления 


Сегодня на рынке программных средств существуют 
и продолжают появляться пакеты полифункциональ- 
ного характера. К ним з первую очередь можно отне- 
сти пакеты для деловых приложений, — Рогш Ріііег, 
РегРогш, ЛеіРогш. Они предназначены для генерации 
форм документов, особым образом структурированной 
информации (бланков, счетов, справок и т.п.), упро- 
щения ввода и обработки информации в них, а также 
ведения архивов. 

Такие пакеты сочетают в себе возможности тексто- 
вых, графических редакторов, электронной таблицы и 
рассчитаны на пользователей, не являющихся профес- 
сионалами в компьютерной области. К деловым паке- 
там относится и пакет Оі^есі Ѵізіоп, который пред- 
ставляет собой нетрадиционное соединение генератора 
форм с >ѴУ8І\ѴѴС-интерфейсом и развитого набора 
математических, экономических и прочих функций. 

Пакет предназначен для: 

- создания и редактирования форм; 

- управления формами; 

- просмотра и вывода на печать форм. 

Судьба любого программного продукта целиком и 
полностью зависит от его реальных свойств, характе- 


ристик и отличий от других пакетов идентичного фун- 
кционального назначения. В чем же состоят эти отли- 
чия у Оі^есі Ѵізіоп? 

Во-первых, и это определяет многие свойства, ОЬ- 
Іесі Ѵізіоп работает в среде АѴіпгіодѵз 3.0, что обеспе- 
чивает стандартный графический интерфейс и разде- 
ление ресурсов компьютера. С точки зрения пользова- 
телей к преимуществам Ѵ/тскпѵз 3.0 можно отнести: 

- представление информации в удобном для воспри- 
ятия виде; 

- большую защищенность системы от несанкциони- 
рованных действий, что позволяет непрофессиональ- 
ным пользователям избегать “рискованных" ситу- 
аций; 

- широкий выбор драйверов принтеров с минимальной 
затратой времени на их установку; 

- практически неограниченный выбор палитры цветов 
изображения и фона; 

- простота установки и настройки пакета; 

- автоматический поиск файлов на дисках; 

- создание пиктограмм в среде АѴіпсІодѵз. 

- широкие текстовые и графические возможности, в 
том числе: 
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(ШЕСТ ѴІЗІСЖ: ПЕРВЫЕ ВПЕЧАТЛЕНИЯ 


выбор шрифтов, их стилей и размеров; 
управление расположением текста; 
выбор линий различной толщины, прямоугольников 
с различной степенью заштрихован ности; 
копирование, удаление перемещение, выделение 
части текста или рисунка. Сложные рисунки могут 
быть созданы в >Ѵіпбоіѵ5 РаіпіЪгизН, а затем пере- 
несены в ОЪіесІ Ѵізіоп. 

Вторая особенность состоит в том, что работая в 
ОЬіесі Ѵізіоп, вы можете присоединить форму к вне- 
шним данным из файлов следующих типов: АЗСІІ, 
Рагабох, 6ВАЗЕ, Вігіеѵе, ООЕ ФОЕ — формат дина- 
мического обмена данными с другими приложениями 
^іпбоіѵз, например, Ехсеі, >Уогб, Іша^еЕбіІ, Місго- 
2га*х, Місго^гаГх Оезі^пег, Согеі Огадѵ). 

Причем после подсоединения внешних данных, 
дальнейшая работа с ними идет по соглашениям про- 


граммы, создавшей эти файлы. Это позволяет исполь- 
зовать уже имеющийся опыт работы с другими при- 
кладными программами, и ослабляет влияние чрезвы- 
чайно мощного фактора, исторического императива, 
которым в основном и объясняется нежелание многих 
пользователей изучать новое программное средств'о. 

Мощным инструментом, отличающим ОЬіесІ Ѵізіоп 
от других “деловых" пакетов, является возможность 
включения в форму стандартных процедур и описания 
процессов заполнения форм. Причем по желанию 
можно определить, какая часть данных будет зано- 
ситься автоматически. Иными словами, пользователь 
получает возможность описать логику заполнения 
формы, используя в качестве средства формализации 
лишь графическое представление процесса, что в тер- 
минологии ОЪ]есІ Ѵізіоп называется “построение де- 
рева решений". Эта процедура может включать про- 


Официальный партнер фирмы ЫОУЕЬЬ ІЫС. 
совместное предприятие ИНТЕРПРОКОМ и 
агентство КомпьютерПресс 
планируют издать в начале 1992 года 

каталог продуктов фирмы ЫоѵеІІ Іпс. 


Каталог объемом около 400 страниц богато иллюстрирован и 
состоит из нескольких глав, в которых описываются 
функциональные возможности продуктов фирмы, а также их 
характеристики, требования к ним со стороны аппаратных и 
программных средств, рекомендации по их использованию. 

В приложении приводится словарь терминов. 

Книга необходима в первую очередь поставщикам 
программных и технических продуктов ЫоѵеН. Также она 
будет полезна широкому кругу пользователей персональных 
компьютеров и локальных вычислительных сетей. Каталог 
необходим как пользователям, уже длительное время 
работающим с локальными сетями, так и пользователям, 
которые поставлены перед проблемой выбора программных 
и аппаратных средств для организации сетей. Пользуясь 
данным каталогом, пользователь сможет правильно выбрать 
тип сетевой операционной системы, программные средства 
ее окружения, в том числе коммуникационные средства, 
технические средства, необходимые для организации 
локальных сетей. 

Изданный на уровне мировых стандартов, этот каталог 
будет стоить всего 195 рублей. 

Заказы от частных лиц и гарантийные письма от 
организаций присылайте по адресу: 

113093 Москва, а/я 37 
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стое множество операций, подобных сложению и вы- 
читанию чисел и более комплексное, с проверкой раз- 
личных условий перед вычислением значений и 
использованием логических выражений, где в качестве 
операндов выступают значения данных, функции или 
имена полей (элементов формы). 

Процессу создания дерева решения обязательно 
предшествует процесс определения всех полей, кото- 
рые будут выступать в качестве вершин дерева. Поле 
можно создать как средствами ОЪ]ес1 Ѵізіоп, так и с 
помощью внешнего источника. 

Область применения пакета ОІ^есі Ѵізіоп обширна, 
начиная с обычного делопроизводства, занимающего 
достаточно почетное место в любой области знания, и 
кончая, например, педагогикой. 


К недостаткам пакета ОЪіесІ Ѵізіоп можно отнести 
повышенные требования пакета к техническим харак- 
теристикам компьютера, что, на наш взгляд, и будет в 
первое время некоторым ограничением в распростра- 
нении пакета на советском рынке. При работе пакета 
требуется ІВМ РС на микропроцессорах Іпіеі 286, 386, 
486, среда МісгозоН АѴіпёоѵз 3.0, объем оперативной 
памяти не менее 1 Мбайта и около 1.5 Мбайт памяти 
на винчестере. 

Испытания пакета проводились на компьютере со 
следующими характеристиками: РС/АТ 386, 25 МГц, 
8 Мбайт оперативной памяти, 122 Мбайта на винче- 
стере, ЗирегѴСА-графика. 

Л. Струкова 


ПУБЛИЧНАЯ ЭЛЕКТРОННАЯ БИБЛИОТЕКА 

Публичная Электронная Библиотека — это избранная коллекция гибких дисков, 

содержащая сотни новых некоммерческих программ типа РиЫіс Е)отаіп и 8Ьаге\ѵаге. 

Публичная Электронная Библиотека — это демонстрационные и оценочные версии 

программ, тексты, документация и другие полезные материалы. 

Публичная Электронная Библиотека — это новый каталог каждые два месяца. 

Публичная Электронная Библиотека — это свободное использование предлагаемых 

программ и умеренная плата для частных лиц, организаций, предприятий и учреждений. 

В нашей коллекции: 

удобный и быстрый редактор ()Е<Ш Айѵапсей, широко используемый программистами- 
профессионалами в США. При объеме 47 Кбайт имеет фантастические возможности; 

база данных несекретных сведений Центрального Разведывательного Управления. 
Множество сведений, которые невозможно найти в справочниках и энциклопедиях; 

обучающая демо-версия пакета Гох-Рго, ♦знакомящая с основными возможностями и 
приемами работы с СУБД Рох-Рго; 

демонстрационные программы из США для брокеров и биржевиков. Полезны также 
разработчикам отечественных программ, так позволяют использовать накопленный 

профессионалами Запада опыт; 

музыкальный генератор Ріапотап — прекрасное умное развлечение. Позволяет вставлять 
музыкальные фрагменты в любые прикладные программы. 

И МНОГОЕ , МНОГОЕ ДРУГОЕ В ПУБЛИЧНОЙ ЭЛЕКТРОННОЙ БИБЛИОТЕКЕ 

Одним словом , Публичная Электронная Библиотека — это то, что Вам нужно! 
Публичная Электронная Библиотека поставляется малым предприятием "Такт” . 

Чтобы получить каталог Публичной Электронной Библиотеки , нужно перечислить на счет № 468802 в 
Коммерческом банке "Днепр" г. Смоленска, МФО 258584, указав в платежном поручении "За текущий выпуск 
каталога ", и прислав нам письмо с Вашим точным почтовым адресом, номером телефона и именем, фамилией и 
должностью лица, сделавшего заказ. Просьба приложить к письму копию платежного поручения либо просто 
указать его номер и дату. 

Адрес: 214036 Смоленск, а/я 248, МП ” Такт ” 

Телефон для справок: ( 081 00 ) 5-58-05 
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ПАРАДОКСАЛЕН ЛИ РАКАООХ? 



П оглощение Вогіапсі корпорации АзНіоп- 
Таіе вызвало не менее, чем шок в рядах 
поклонников <ІВА5Е. Примерно такое же 
чувство испытали и мы. Свернет ли 
Вогіапсі все работы, связанные с 
продолжением разработки линии (ІВА5Е, 
или нет — пока неизвестно. Но судя по 
всему, в сфере баз данных происходит 
смена поколений, и поэтому мы спешим 
представить нового лидера — СУБД 
Рагасіох. 


Парадоксален ли Рагасіох! 


“И гений , парадоксов друг ..." 

А .С. Пушкин 

» 

Рагасіох — первое знакомство 

Система управления базами данных Рагасіох явля- 
ется гибким современным средством построения и ве- 
дения реляционных баз данных, снабженным удобным 
диалоговым интерфейсом, языком программирования и 
средствами автоматизированного создания отчетов. 

Коммерческий успех Рагасіох определился, начиная 
с версии 2.0, когда СУБД поставлялась компанией 
АЫЗА БоІЬѵаге. Приобретение этой фирмы одним из 
ведущих производителей программного обеспечения, 
корпорацией Вогіапсі, привело к значительному рас- 
ширению возможностей и улучшению пользователь- 
ских характеристик Рагасіох за счет применения соб- 
ственных технологических новаций Вогіапсі (версии, 
начиная с Рагасіох 3.0). 

В целоме, по оценкам многих специалистов, Рагасіох 
приобретает черты стандарта де-факто современной 
информатики в области баз данных, приходя на смену 
семейству ёВазе. 

Причиной этому являются следующие весомые пре- 
имущества Рагасіох: 

- высокая производительность; 

- простой и наглядный метод построения запросов по 
образцу ((}иегу-Ьу-Ехатр1е); 


- средства графической визуализации данных; 

- ведение жу риала СУБД; 

низкие требования к ресурсам компьютера 
(благодаря технологии ѴЯООММ); 

- наличие интерфейса со многими типами сетевых 
серверов баз данных (пакеты 5>(}Ь Ііпк); 

- возможность (с помощью Рагасіох Еп^іпе 2.0) созда- 
ния прикладных программ обработки баз данных на 
языках высокого уровня типа МісгозоН С 5.1, ТигЬо 

С++, ТигЬо С 2.0, ТигЬо Разсаі. 

Удобство и надежность эксплуатации Рагасіох в ло- 
кальной сети позволяет использовать его как высокоп- 
роизводительное оконечное средство доступа к удален- 
ным данным, включая обращение к базам данных на 
больших ЭВМ. 

По данным независимой организации ЗоІЬѵаге РиЬ- 
ІізНіпз Аззосіаііоп, доля Рагасіох среди применяемых в 
США СУБД увеличилась за первые 5 месяцев 1990 
года более, чем в два раза и достигла 20%. В мае 
1990 года 40% вновь приобретаемых СУБД пришлось 
на Рагасіох — больше, чем у любого из конкурентов. 
К концу 1990 года Рагасіох захватил 34.5% рынка 
СУБД для ІВМ-совместимых компьютеров — больше 
любой другой СУБД в США. 

Очевидно, что такие убедительные показатели не- 
минуемо приведут ко все более широкому распростра- 
нению легальных (как и пиратски похищенных) ко- 
пий Рагасіох в нашей стране. 
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Общие впечатления разработчика 

Сравнительные характеристики СУБД в основном 
совпадают в различных статьях и обзорах, посвящен- 
ных базам данных. Действительно, Рагабох — удо- 
бная, мощная, хорошо продуманная и изящно скон- 
струированная система, обеспечивающая эффектив- 
ность труда программиста и возможность создавать 
эффективно работающие приложения. Авторы наде- 
ются, что некоторые отмеченные недостатки текущих 
версий со временем будут устранены и Рагабох будет 
расширен именно теми возможностями, нехватка ко- 
торых кажется столь очевидной. 

Главным парадоксом Рагабох является, на наш 
взгляд, сочетание простоты и удобства с широким на- 
бором функциональных возможностей обработки дан- 
ных. 

Работая в диалоговом режиме меню (без програм- 
мирования) можно создать довольно сложную систему 
обработки данных, включающую средства ввода и ре- 
дактирования входных документов, поиска и обра- 
ботки данных и получения разнообразных выходных 
документов. Диалоговый интерфейс Рагабох нагляд- 
нее, чем, например, подсистема Аззізіапі СУБД 
6ВА8Е III Ріиз. Пользователь в каждом режиме полу- 
чает доступ к крупному функциональному блоку с по- 
нятным входом и выходом, а не к элементарной опе- 
рации, как в 6ВА8Е. Объяснение простое: в Рагабох 
диалог ориентирован на удобство работы, в то время 
как в 6ВА5Е — на простоту преобразования в ко- 
манды этой СУБД. 

Достоинством диалогового монитора Рагабох явля- 
ется активное и единообразное использование во всех 
режимах наряду с иерархическими меню функци- 
ональных ключей и СТВЬ/АЦГ-клавиш. 

Для описания структуры базы данных достаточно 
заполнить простую двухколоночную таблицу, указав 
имена и типы полей. Дополнительное удобство — 
возможность использования структуры уже существу- 
ющей таблицы в качестве отправного пункта при со- 
здании новой. 

После описания структуры можно разработать эк- 
ранные формы для ввода и редактирования данных 
или непосредственно начинать ввод, используя стан- 
дартные формы табличного или бланкового типа. При 
создании экранных форм пользователь может управ- 
лять размещением полей на экране, заданием поясня- 
ющих текстов, выбором цветовой палитры для экрана 
или его частей. Существует возможность связки , в 
одной форме нескольких таблиц по составному ключу. 
При этом допустимы связи между записями типа 
“один-к-одному“ или “один-ко-многим“. Возможно 
формирование значений некоторого поля данных по- 
средством выбора значения из домена (таблицы -спра- 
вочника). 

При вводе и коррекции данных могут использо- 
ваться до 16 форм ввода, связанных с текущей табли- 
цей. Одновременно можно обрабатывать несколько 
форм, связанных с разными таблицами. 


Язык запросов вызывает немой восторг программи- 
ста. В Рагабох реализован практически полный язык 
запросов (}ВЕ. Синтаксис его близок к специфика- 
циям фирмы ІВМ и публикациям автора языка, 
М.Злуфа (М.ХІооО. С помощью (}ВЕ можно реализо- 
вать сложнейшие операции поиска и обработки дан- 
ных. Следует отметить, что процедурные, рассчитан- 
ные на программиста средства поиска, например, в 
Сііррег или РохЬазе функционально беднее, чем дек- 
ларативные (непроцедурные) средства (^ВЕ в Рагабох. 

Проведенные нами проверки показали, что оценки 
производительности поисковых средств Рагабох, по- 
стоянно обеспечивающие ему одно из первых мест по 
скорости поиска в сравнительных обзорах СУБД для 
персональных компьютеров, вполне соответствуют 
действительности. 

Отметим, что фирма-разработчик считает диалого- 
вые возможности Рагабох средствами, ориентирован- 
ными на пользователя-непрограммиста. Американские 
программисты, конечно же, имеют в виду американ- 
ских пользователей и сложившуюся в США систему, 
при которой в подготовку сотрудников фирмы к при- 
менению автоматизированных рабочих мест вклады- 
ваются огромные средства. В нашей стране, за исклю- 
чением редких случаев, между пользователем и 
“голой" СУБД должен стоять программист, созда- 
ющий адекватные уровню подготовки данного пользо- 
вателя средства общения. Поскольку разрабатывать 
десятки новых приложений программированием “в 
лоб“ неоправданно, возможности развития программ в 
Рагабох мы будем оценивать не только с точки зрения 
написания конкретных приложений, но и создания 
инструментальных средств. 

В Рагабох реализован высокопроизводительный и 
гибкий генератор отчетов, позволяющий создавать вы- 
ходные документы табличного и анкетного типа. По- 
мимо стандартных для многих генераторов отчетов, в 
Рагабох реализованы следующие возможности: 

- вычисляемые поля отчета; 

- многотабличные отчеты; 

- вложенные группировки и подсчет итогов; 

- получение более широких, чем каретка принтера, 
выходных документов (с выводом по частям). 

В целом, встроенный генератор отчетов Рагабох со- 
поставим по функциональным возможностям и про- 
стоте использования с таким специализированным па- 
кетом, как Веіаііопаі Керогі \ѴгіІег фирмы Сопсепігіс 
Эаіа Бузіегпз (последний работает с файлами 6ВА$Е). 

Средства разработки сложных приложений 

Для разработки приложений Рагабох имеет встро- 
енный язык программирования РАЬ. В сущности, РАЬ 
объединяет два языка — язык клавиатурных макроко- 
манд и собственно систему программирования. Любую 
последовательность клавиш, использованную в про- 
цессе диалога с системой, можно сохранить в файле в 
виде программы-макрокоманды и затем выполнить не- 
обходимое число раз. Язык программирования позво- 
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ПАРАДОКСАЛЕН ЛИ РАКАЛОХ? 


ляет объединять такие макрокоманды, а также вклю- 
чать собственные команды и функции языка. В РАЬ 
реализованы необходимые управляющие конструк- 
ции — условия, ветвления, циклы. В языке существует 
механизм использования процедур со средствами пе- 
редачи параметров и возврата значений. Данные в 
языке представляются полями таблиц базы данных 
или переменными. Тип поля базы данных определя- 
ется при его создании и остается в программе неиз- 
менным. Тип переменной определяется типом присво- 
енного ей значения и может быть изменен оператором 
присваивания. Простая переменная может быть сим- 
вольного типа, типа “дата", логического типа и одного 
из числовых типов — зНоП іпіе^ег (16-битное целое со 
знаком), сштепсу (для денежных сумм — число с 
двумя десятичными знаками) и геаі (переменная дей- 
ствительного типа двойной точности). Возможно 
использование одномерных массивов. Компоненты 
массива могут быть различных типов. Переменные в 
процедурах могут иметь локальные или глобальные 
области действия. 

Команды РАЬ обеспечивают выполнение 
“крупноблочных" операций Рагабох — одной-двумя 
командами можно обеспечить просмотр и редактиро- 
вание базы данных по любой из созданных экранных 
форм, выполнение запросов, подготовку отчетов и т.д. 
При этом можно использовать практически все диало- 
говые возможности Рагабох, расширяя их средствами 
реакции на нестандартные клавиши или заменяя 
стандартные действия Рагабох на необходимые в кон- 
кретной программе. 

Набор встроенных функций РАЬ достаточно полон 
и включает в себя: 

- функции работы с датой и временем; 

- функции финансовых вычислений; 

- функции получения сведений об объектах базы дан- 
ных и программы, о рабочей области и параметрах 
системы; 

- функции ввода-вывода; 

- математические функции; 

- статистические функции; 

- функции работы со строками. 

Система программирования содержит интерпрета- 
тор, редактор и отладчик. Для повышения производи- 
тельности труда разработчика приложений в Рагабох 
реализован мощный генератор приложений РРго&, по- 
зволяющий существенно сократить время на проведе- 
ние рутинных операций обработки данных в новых 
прикладных задачах. Кроме того, РРгоя сам по себе 
может служить неплохим самоучителем работе с РАЬ. 

При использовании в локальной сети Рагабох обес- 
печивает автоматическую блокировку, разблокирова- 
ние и запрещение блокирования своих объектов в за- 
висимости от типа операции их обработки. Все эти 
функции осуществляются автоматически ядром си- 
стемы. При разработке сетевого приложения, напри- 
мер, на Сііррег, функциональные режимы, которые 
Рагабох выполняет самостоятельно, необходимо про- 
граммировать вручную. 


Документация и система “помощи" 

Документация Рагабох подробна, хорошо организо- 
вана, содержит большое количество примеров. Ее удо- 
бно использовать и при начальном знакомстве с си- 
стемой, и при получении справок в ходе работы. К 
сожалению, все это нельзя отнести к системе помощи. 
Несмотря на большой объем сведений и контекстную 
чувствительность, она обладает весьма серьезными не- 
достатками: 

- пауза при вызове Неір заметна даже на машинах 
типа АТ; 

- индекс помощи практически не структурирован, по- 
иск по нему затруднен; 

- практически отсутствуют ссылки на близкие по 
смыслу или связанные понятия. 

Кроме того, раздел со сведениями о командах и 
функциях языка, пожалуй, наименее полон и вклю- 
чает только название команды или функции и ее 
формат — без каких-либо комментариев. Хорошо, что 
этот недостаток ощущается преимущественно про- 
граммистами-профессионалами, а не конечными поль- 
зователями. 

Структуры данных 

Рагабох — “истинно" реляционная СУБД, что вы- 
годно отличает его от семейства сШАЗЕ (Сііррег, 
РохВазе и РохРго, сШХЬ и проч.). Действительно, 
табличная форма хранения данных часто приводит к 
тому, что программные средства семейства бВАЗЕ 
ошибочно относят к классу реляционных СУБД. ,В то 
же время, в них отсутствует главная отличительная 
черта реляционных систем, языковые средства мани- 
пулирования данными, — реляционная алгебра или 
средства реляционного исчисления. Наш опыт показы- 
вает, что программы из семейства сіВАЗЕ правильнее 
было бы отнести к классу СУБД с плоскими файлами, 
а по некоторым признакам они вообще ближе к си- 
стемам файлового доступа, а не к СУБД. 

Реляционность Рагабох, заключающаяся в мощном, 
реляционно-полном языке манипулирования дан- 
ными, — несомненное достоинство, обеспечивающее 
превосходство над семейством (1ВА5Е. В то же время, 
за счет великолепных технологических решений Рага- 
сіох в основном лишен главного недостатка, традици- 
онно связываемого с реляционными системами, невы- 
сокой производительности. По скорости выполнения 
поисковых операций он заметно опережает и Сііррег, 
и РохЬазе — чемпионов семейства <ША5Е. 

Сама по себе реляционная модель не лишена недо- 
статков. Основной из них — неудобство отображения 
семантики предметной области средствами описания 
схемы базы данных. Так, например, в Рагабох суще- 
ствует понятие семейства файлов, ассоциированных с 
таблицей-отношением — экранные формы, отчеты, 
индексы и т.п. Многие операции работы с таблицей 
(реструктуризация, копирование, удаление) автомати- 
чески производят адекватные изменения с членами 


КомпьютерПресс 1Г91 




СТРАНА ПО ИМЕНИ ВОКЬАОД 


61 


семейства. Вызывает сожаление отсутствие таких воз- 
можностей для совокупности таблиц, входящих в не- 
которую базу данных. Структура многотабличной базы 
данных (а именно в ней в значительной мере сосредо- 
точено семантическое описание предметной области) в 
Рагаёох не фиксируется. Связи между таблицами, 
ограничения целостности задаются в описаниях эк- 
ранных форм и отчетов и в значительной степени в 
программном коде приложения, поддерживающего 
базу данных. 

Такой способ представления семантики, очевидно, 
далек от идеала: средства моделирования данных ком- 
мерческих реляционных систем (в том числе и Рага- 
ёох), ориентированы на описание таблиц, а не объек- 
тов реального мира, их свойств и взаимосвязей. 

Справедливости ради следует отметить, что члены 
семейства ёВАЗЕ вообще "не доросли" до того, чтобы 
их критиковать с точки зрения большей или меньшей 
семантичности моделей данных. 

К недостаткам реляционной структуры данных 
Рагаёох можно отнести также отсутствие аналога тек- 
стовых полей данных с переменной длиной и возмож- 
ность использования только единственного (хотя и со- 
ставного) ключа таблицы для связи ее с другими таб- 
лицами. 

Разработка приложений — 
шаг навстречу пользователю 

Высокая эффективность Рагаёох как средства 
управления данными приводит к мысли о возможности 
его использования в составе больших разнородных си- 
стем обработки информации, где СУБД, как правило, 
является одной из главных компонент. За последние 
полтора года коллектив, к которому принадлежат ав- 
торы, выполнил следующие разработки: 

- создание оболочки экспертной системы, включающей 
Рагаёох в качестве системы хранения и обработки 
данных; 

- стыковка Рагаёох с системой обработки графических 
данных и большой программой численного анализа, 
реализованной на Рогігап; 

- разработка прикладной информационной системы на 
основе баз данных общим объемом более 17 тысяч 
строк исходного текста на РАЬ. 

Во всех этих случаях приходилось решать проблемы 
взаимодействия Рагаёох с другими программами и па- 
кетами программ, оптимизировать критические по 
времени исполнения участки РАЬ-программ, доби- 
ваться эффективного использования памяти. 

В Рагаёох реализована возможность запуска про- 
грамм операционной системы командами Кліп и Кліп- 
Ві&. Нетрудно догадаться, что выполнение первой из 
них оставляет для запускаемой программы не так уж 
много свободной памяти, а выполнение второй требует 
заметного времени. 

Передача параметров внешней программе возможна 
либо через командную строку запуска, формируемую в 
Рагаёох, либо через файл. Возврат значений — только 


через файл, а средства Рагаёох для работы с вне- 
шними файлами 005, на наш взгляд, развиты недо- 
статочно. 

Кроме того, существует целый ряд тщательно огова- 
риваемых в документации запретов на действия, осу- 
ществляемые внешней программой. 

Таким образом, возможности связи приложений, 
реализованных на Рагаёох, с миром внешних, напи- 
санных не на РАЬ, программ, оставляют желать луч- 
шего. Удачным исключением можно считать, пожа- 
луй, простую и удобную систему экспорта/импорта 
данных. 

Для обеспечения эффективного использования па- 
мяти при разработке программ на РАЬ следует: 

- тщательно проектировать модульную структуру про- 
граммы; 

- своевременно применять в тексте программы опера- 
торы освобождения памяти, занимаемой перемен- 
ными и процедурами (Кеіеазе); 

- избегать рекурсивных вызовов процедур; 

- своевременно закрывать файлы базы данных. 

При соблюдении этих несложных правил можно со- 
здавать приложения практически неограниченного 
размера. В то же время, если пренебречь этими требо- 
ваниями, неработоспособной может стать сравни- 
тельно небольшая программа. Несмотря на это, опыт 
показывает, что управление памятью в больших про- 
граммах на РАЬ может быть осуществлено значи- 
тельно эффективнее, чем, например, в Сііррег 5шп- 
тег'87 или Сііррег 5.0. 

В целом, система программирования РАЬ — это си- 
стема интерпретирующего типа, поэтому, несмотря на 
исключительно быструю работу с базой данных, неко- 
торые программы общего назначения в Рагаёох могут 
работать сравнительно медленно. Действительно, про- 
изводительность предварительно откомпилированных 
программ, например, в задачах математических расче- 
тов заметно выше. Простой пример — расчет суммы 
квадратов чисел от 1 до 10000. Тест проводился на 
машине типа РС АТ с тактовой частотой ІОМгц. 

Пакет ТигЬо С++ Сііррег ёВА5Е ІІІ+ РАЬ 

Время 

(сек.) 3.242 19.000 256.000 69.000 

В то же в|)емя, нельзя не отметить практически че- 
тырехкратное преимущество Рагаёох по отношению к 

другому интерпретатору — ёВАЗЕ III Ріиз. 

« 

А если нужно еще быстрее? 

Большие надежды разработчиков приложений Рага- 
ёох связаны с новым продуктом фирмы Вогіапё, Рага- 
ёох Еп^іпе, который представляет собой библиотеку 
функций для работы с базами данных Рагаёох. С ее 
помощью можно выполнить из программы, написан- 
ной на языках С или Разсаі, большинство операций по 
созданию и ведению баз данных, провести поиск в 
таблицах, разработать сетевые приложения, использу- 
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ющие богатые средства Рагасіох для коллективного до- 
ступа к базам данных. К сожалению, в текущей вер- 
сии Рагасіох Еп^іпе нельзя непосредственно из про- 
граммы на языке высокого уровня использовать такие 
“изюминки" Рагасіох, как экранные формы, запросы и 
отчеты. 

Разработчики фирмы Вогіапсі в рамках Рагасіох Еп- 
2 Іпе 2.0 реализовали не только возможность работы с 
файлами Рагасіох из языка ТигЬо Разсаі, но и про- 
граммный интерфейс к ОІХ (динамически компону- 
емым библиотекам) МісгозоН >Ѵіпбо^ѵз 3.0. В резуль- 
тате программисты всего мира получили’ уникальный 
набор инструментальных средств для работы с базами 
данных, до сих пор отсутствовавший в среде МЗ-008. 

Диалог должен быть современным! 

Набор команд РАЬ, используемых для организации 
диалога с пользователем, существенно превосходит 
возможности сІВАЗЕ, но уступает аналогичным сред- 
ствам такой системы программирования, как Сііррег. 
Реализация меню в Рагасіох осуществляется в так на- 
зываемом Ьоіиз-подобном стиле (горизонтальное раз- 
ворачивающееся меню со строкой-комментарием). В 
то же время, с помощью РАЬ и процедур из поставля- 
емого с Рагасіох набора ТооІКй (полезные примеры 
программ на РАЬ) можно запрограммировать и более 
удобные всплывающие меню. 

В языке программирования РАЬ, к сожалению, 
отсутствует понятие окна и средств для работы с 
окнами. Вместо этого введено понятие занавеса, эк- 
ранной поверхности, на которой Рагасіох производит 
свои действия. Эта поверхность может быть закрыта 
занавесом (возможно, прозрачным), на котором ото- 
бражается экранный вывод РАЬ-программы. При про- 
граммировании это не всегда удобно, да и выглядит 


как-то несовременно. Не поддерживается интерфейс с 
мышью. Оставляет желать лучшего и управление зву- 
ком. 

Команды ввода-вывода на экран не позволяют со- 
хранять, очищать или закрашивать область экрана 
(занавеса). Ввод данных в базу удобно реализуется в 
виде экранных форм, а вот средства для запроса ка- 
ких-либо параметров, не являющихся полями базы 
данных, недостаточны. Нельзя, например, менять 
форму' и цвет курсора. В целом, все, что касается про- 
граммно управляемых средства диалога, оставляет ши- 
рокое поле для совершенствований. 

Следует отметить, что в ближайших версиях и сам 
Рагасіох, а не только Рагасіох Еіцрпе, будет работать в 
среде >Ѵіпдодѵз. Первые шаги в этом направлении сде- 
ланы в версии 3.5. В ее дистрибутив входят .РІР 
файлы и иконки АѴіпскиѵз для Рагасіох и его генера- 
тора приложений РРгоя. На рубеже 1992 года ожида- 
ется и появление специализированной версии Рагасіох 

ДЛЯ >УІПСІОДѴ5. 

В заключение следует отметить, что предъявление 
программистами таких требований к Рагасіох, который 
является проблемно-ориентированной программой для 
ведения баз данных (СУБД), свидетельствует, в пер- 
вую очередь, о его огромном потенциале в качестве 
средства создания автоматизированных рабочих мест 
различного назначения. Действительно, вряд ли кто- 
нибудь будет ожидать многого от программной си- 
стемы, которая не удовлетворяет пользовательским 
требованиям сама по себе. В то же время, мощную, 
гибкую и удобную для разработчиков прикладных про- 
грамм систему всегда хочется улучшить одной-двумя 
ценными характеристиками. 

Д.Хан-Магометов, 
К.Раннев , А.Зотов 


2епі1Н Эаіа 8узіетз демон- 
стрировал на выставке Сошбех в 
Лас-Вегасе новый компьютер- 
блокнот (поіеЬоок) МазІегзРогі 
3868Ье. 208 выпустила также 
настольный компьютер на про- 
цессоре 4868Х. 

МазіегзРогі 3868Ье выполнен 
на новом 25-мегагерцовом про- 
цессоре І803868Ц который рабо- 
. тает на 25 процентов быстрее, 
чем ранее имевшийся 3868Х. 
Компьютер имеет 85-мегабайт- 
ный жесткий диск, улучшенный 
параллельный порт, дисплей 
УСА, и 2 Мбайта ОЗУ. Машина 


весит 7 фунтов (3.15 кг) и нач- 
нет продаваться в США в ноябре 
за 5,000 долларов. 

Примененный в рабочей стан- 
ции 2-4868Х/25Е процессор 
804868Х имеет производитель- 
ность на уровне 486ЭХ, работа- 
ющего с такой же тактовой час- 
тотой. Разница состоит в том, 
что в нем не встроен модуль вы- 
числений с плавающей точкой. 

Компьютер имеет графичес- 
кий адаптер 2-649 Техаз Іпзіги- 
тепіз СгарНісз АгсНііесіиге 
(сокращенно — ТІСА), обеспе- 
чивающий разрешающую спо- 


собность 1024x768 пикселей и до 
256 цветов. 

2-4868Х/25Е с винчестером 
емкостью 200 Мбайт называется 
Мосіеі 200 (6199 долларов), а без 
винчестера и видеоадаптера — 
Мосіеі 1 (4049 долларов). Обе 

машины имеют 4 Мбайта ОЗУ с 
возможностью расширения до 
32 Мбайт на основной плате, 
три слота ЕІ8А (ЕхІепбесІ 
Іпёизігу Зіапдагсі АгсЫІесіиге), и 
поддержку математического со- 
процессора >Уеііек 4167 . 

А^си ъЪуІех Асия Меіпюгк, 
28 ОсіоЪег 1991 
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]ѴІ ассовое освоение пользователями 
техники персональных вычислений 
быстрыми темпами формирует < 

потребности совместного 
использования информации. Эта 
тенденция ведет к созданию баз данных 
коллективного пользования, в которых 
центральным технологическим звеном 
становятся серверы баз данных. 



Серверы баз данных 


Введение 

Программные средства серверов баз данных обес- 
печивают реализацию многопользовательских прило- 
жений, централизованное хранение, целостность и 
безопасность данных. Производительность серверов 
баз данных на порядок выше по сравнению с тради- 
ционными файл-серверами, которые используются в 
локальных сетях. Кроме того, 8(2Ь-серверы баз данных 
для ПЭВМ обеспечивают многие возможности боль- 
ших и мини-ЭВМ по ценам значительно более низ- 
ким, соответствующим ценам ПЭВМ. 

Данный обзор посвящен анализу основных проблем 
в развитии технологии серверов баз данных, а также 
рассмотрению возможностей некоторых зарубежных 
программных средств, реализующих новую техно- 
логию. 

Прежде чем перейти к такому анализу, хотелось бы 
более подробно рассмотреть основные принципы 
работы и отличия серверов баз данных от тра- 
диционных файл-серверов. 

Локальные вычислительные сети (ЛВС), первона- 
чально созданные для совместного использования до- 
рогостоящего периферийного оборудования, эволюцио- 
нировали со временем до такой степени, что стал воз- 
можен доступ многих пользователей к одним и тем же 


файлам, и для многих персональных систем управле- 
ния базами данных были предложены сетевые версии. 
Однако скоро стало ясно, что сетевые СУБД, основан- 
ные на модели файл-сервера, недостаточно мощны для 
мини-ЭВМ. Но, почему? Ответ на этот вопрос — ос- 
нова для понимания принципов работы серверов баз 
данных. 

Файл-серверу на микропроцессоре 386 с тактовой 
• частотой 25 МГц и объемом памяти жесткого диска 40 
Мб трудно соперничать с мини-ЭВМ. Конечно, можно 
использовать устройства оптической памяти, чтобы 
имитировать огромную память миникомпьютера. Но в 
нагруженной сети неизбежно встанет проблема произ- 
водительности, а также безопасности и целостности 
данных. 

Производительность является проблемой не потому, 
что современным 386 процессорам не хватает требуе- 
мой мощности, а потому, что сегодняшние файл-сер- 
веры используют принцип “все или ничего 44 для ис- 
полнения запросов рабочих станций. Полные копии 
файлов базы данных постоянно перемещаются вперед- 
назад по сети. Проблемы с безопасностью и целостно- 
стью данных возникают из-за того, что файл-серверы 
изначально не были сконструированы с учетом целост- 
ности данных и их восстановления в случае аварии, 
неявного распараллеливания задач (ітріісіі сопсиг- 
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гепсу) и централизованного контроля управления дан- 
ными, типичными функциями, выполняемыми СУБД 
на средних и больших ЭВМ. 

Архитектура “клиент-сервер" (С$А — СНеп* Зегѵег 
АгсНИесіиге) заменила модель “файл-сервера" на бо- 
лее мощную, состоящую из “клиентов" и “серверов", 
что позволило совместить достоинства однопользова- 
тельских (высокий уровень диалоговой поддержки, 
дружественный интерфейс и низкую цену) и более 
крупных компьютерных систем (поддержка целостнос- 
ти и защита данных, многозадачность). 

В классическом понимании СУБД представляет со- 
бой набор программ, позволяющий создавать и под- 
держивать базу данных. С функциональной же точки 
зрения СУБД выглядит иначе. 

Функционально СУБД состоит из трех частей: ядра 
базы данных (еп&іпе), языка (Іап^иа^е) и инструмен- 
тальных средств программирования (іооіз). Инстру- 
ментальные средства относятся к интерфейсу пользо- 
вателя, или внешнему интерфейсу, который мы ис- 
пользуем. Они могут включать процессор обработки 
запросов на языке ЗСД, или (^ВЕ ((}иегу Ьу Ехатріе 
— язык запросов по образцу). Язык — это совокуп- 
ность процедурных и непроцедурных команд, поддер- 
живаемых СУБД. Ядро базы данных выполняет все ос- 
тальные функции, которые обычно включаются в по- 
нятие “обработка базы данных". Термины “ядро" (еп- 
Яіпе), “сервер" (зегѵег) и “внутренний интерфейс" 
(Ьаск епб) являются синонимами. Основная идея мо- 
дели “клиент-сервер" заключается в том, чтобы распо- 
лагать серверы на мощных машинах, а приложениям, 
использующим языковые компоненты СУБД, обеспе- 
чить доступ к ним с менее мощных машин-клиентов 
посредством внешних интерфейсов. Тем самым ис- 
пользование серверов базы данных позволяет задейст- 
вовать ресурсы как самого сервера базы данных, так и 
клиентов, менее мощных компьютеров. Обособляя опе- 
рации работы с базой данных, архитектура “клиент- 
сервер" позволяет объединить усилия всех компонен- 
тов системы. Сервер базы данных или внутренний ин- 
терфейс (Ьаск-епб) обслуживает базу и отвечает за» 
целостность и сохранность данных, а также обеспечи- 
вает операции ввода/вывода при доступе клиента к 
информации. 

Ввод/вывод в базе данных основан не на физичес- 
ком дроблении данных, а на логическом. Это означа- 
ет, что вместо того, чтобы отправлять клиентам пол- 
ные копии файлов базы данных, сервер посылает им 
только логически необходимые порции, уменьшая тем 
самым трафик сети. 

Вообще говоря, серверы баз данных совсем не обя- 
зательно используют язык ЗС^Ь. Но большинство сер- 
веров, разрабатываемых сегодня, делает это, т.к. 3(}Б 
очень удобен как язык для описания логических под- 
множеств базы данных. 

В архитектуре “клиент-сервер" интерфейс пользо- 
вателя, отображения и запросы хранятся отдельно от 
системы управления реальными данными и их фильт- 
ров. Внешние прикладные программы сориентированы 


более на представление информации клиенту. Сервер 
же обрабатывает запросы прикладных программ, вы- 
бирает необходимые данные, посылает их клиентам по 
сети и производит обновление информации. 

Серверы баз данных расширяют диапазон программ 
пользователей, которым доступны данные в СУБД. 
Это происходит за счет централизованного хранения 
данных (в отличие от файл-серверов, поддерживаю- 
щих отдельные файлы для каждого типа 
приложений). Обращаться к данным могут не только 
специально написанные прикладные программы базы 
данных, но и электронные таблицы, настольные 
издательства или текстовые процессоры. Сервер базы 
данных обеспечивает интеграцию данных независимо 
от использующих их приложений. Данные в СУБД 
всегда поддерживаются в актуальном состоянии и 
могут быть использованы совместно многими поль- 
зователями. Централизованное хранение и програм- 
мные средства сервера базы данных обеспечивают вы- 
полнение таких важных функций СУБД, как диалого- 
вое управление и восстановление целостности храни- 
мой информации после сбоя. 

Все перечисленные выше функции серверов баз 
данных будут более подробно рассмотрены в следую- 
щих разделах. 

Тенденции развития рынка 

Рынок программных средств серверов баз данных в 
настоящее время весьма активно развивается и делит- 
ся на две части. Одна из них — это крайне необходи- 
мые приложения, позволяющие пользователям и раз- 
работчикам на основе ПЭВМ и серверов баз данных 
создавать системы, для которых ранее использовались 
универсальные или мини-ЭВМ. Это рынок, где разви- 
вались и впредь будут развиваться административные 
информационные системы, выполненные на Си, 
Коболе или программных средствах четвертого 
поколения (ЗС^Ь \ѴіпсІо\ѵ5 или (Шазе). В таких 
системах для разработчиков и пользователей очень 
важны возможности создания надежных программ и 
обеспечения их работоспособности в многополь- 
зовательском режиме в локальных сетях ПЭВМ. 

Другая часть рынка программных средств серверов 
баз данных — это приложения для создания структур 
автоматизации типа “групповое обеспечение/офис" 
(Ягочрѵаге/оНісе). Это системы, в которых ядро мно- 
гопользовательской базы данных используется для ав- 
томатизации работы офиса, будь то электронная почта 
или электронные таблицы, связанные с базами данных 
(пакеты Ьоіиз 1-2-3, Ехсеі). 

В настоящее время на рынке зарубежных ПС серве- 
ров баз данных имеется около десяти основных про- 
дуктов [2]. Сравнительные характеристики этих про- 
дуктов приведены в таблице. Среди наиболее популяр- 
ных программных продуктов можно назвать 8(}Ь 
Зегѵег (МісгозоН), 8(}Ь Вазе Зегѵег (Сиріа 
ТесНпоІо^у), Огасіе Зегѵег (Огасіе Согр.). 
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Таблица сравнительных характеристик серверов 


Возможности ядра базы данных 


Продукт/Версия/ 

Компания 

| Объем 
| опера- 
тивной 
| памяти 

1 

1 

1 

Объем | Макс, число | Макс. 

внеш- 1 ; — | 

ней | открыт- | полей |текс-гс 
памяти |ых окон | записи | поля 

і і і 

длина 

| ЧИСЛОВО 1 

| го поля| 



Типы 

полей 

1 


г 

2 1 

г 

3 1 

4 

Г 

5 

6 





7 


Етргезз В0ВМ8 4 

1 1 МБ 

1 

15 МБ | 

НО | 

9999 

1 


1 15 | 

і. 

с, 

р. 

0. 

м, 

Ві. 0 

Етргезз 8о1Чиаге 


1 

1 

1 

1 

1 

| 




1 1 
1 1 







ИеМаге 801. 2.10 

1 1 МБ 

1 

1 

5.4 МБ | 

255 | 

но 

1 

255 

1 1 

1 15 | 

і, 

с. 

и 

Р. 

0, 

м 

Иоѵеі 1 


1 

| 

і 

1 

1 

1 


1 

1 


1 1 
1 1 







Огасіе Зегѵег 1.0 

1 8 МБ 

1 

20 МБ | 

НЭ 1 

254 

1 

64 

1 38 | 

і, 

с, 

N. 

0 



Огасіе 


1 

1 

1 

1 

1 

1 


1 

1 


1 1 
1 1 







801. 8егѵег 1.1 

I 8 МБ 

1 

14 МБ | 

10.000 | 

255 

1 

но 

1 

1 15 | 

і, 

с. 

Р, 

Р, 

1. 

0, М, Ві, ц 

Иісгозо^і: 

і 

1 

1 

і 

1 

1 

1 


1 

1 


1 1 
1 1 







801 8егѵег 4.0 

і і 

| 6-8 МБ | 

30 МБ | 

НО 1 

250 

1 

255 

1 НО 1 

і, 

с, 

Р, 

и 

0 , 


8уЬазе 

1 

1 

1 

1 

1 

1 

1 

1 


1 

1 


1 1 
1 1 







80І_Вазе 4.0.1 

| 4 МБ 

1 

1 

1 МБ | 

НО 1 

254 

1 

1 

НО 

1 1 
1 22 | 

і, 

с. 

р. 

о. 

р, 

0, Ві 

биріга 

1 

1 

1 

1 


1 


1 1 







Тесііпоіодіез 

1 

1 

1 

1 

1 

1 

1 

1 


1 

1 


1 1 
1 1 







ѴІА/0ВЕ 1.2.3, 

| 640 КБ | 

1 

4.5 МБ | 

НО 1 

НО 

1 

1 

НО 

1 1 
1 16 | 

і, 

с, 

р. 

і. 

0. 

Ві 

ѴІА Іп^огшаііоп 

1 

1 


1 


1 


1 1 







8узі:етз 

1 

1 

1 

1 

1 

1 

1 


1 

1 


1 1 
1 1 







Х0В 2.30 

1 1 
| 640 КБ | 

3.5 МБ | 

246 | 

400 

1 

1 

4056 

1 1 
1 15 | 

і, 

с, 

N. 

о, 

Ві 


ХйВ Зузіетз 

1 

1 

1 

1 


1 


1 1 








НО - в зависимости от типа компьютера 


В графе 7 приняты следующие сокращения типов полей: 


I (Іп*едег) - целое; 

С (Сйагасіег) - символ; 

Р (Ріоа*) - число с плавающей 
точкой; 


Р (РаскесІ) - упакованный 
формат; 

I. (БодісаО - логический; 
Р (Оа*е) - дата; 


М (Мето) - текстовое поле; 

Ві (ВіоЬ) - двоичный формат; 

0 (Узег ОеНпесІ) - определяемый 
пользователем. 


КомпьютерПресс 1Г91 







66 


СЕРВЕРЫ БАЗ ДАННЫХ 


Таблица сравнительных характеристик серверов (продолжение) 



Продукт/Версия/ | Кол-во правил 

Компания ІКодда, поддер- 

Іживаемых СУБД 
1 

| Реляционные 

| ВОЗМОЖНОСТИ 

| Реализация 
| интерфейса 
| 3-го покол. 
I (3 ЗОЮ 

і 

8 

1 9 

1 10 

Етрге$$ В0ВМ8 4 

12 

1 V РК РК N0 

В 

Етргезз ЗоІЧиаге | 


М ВІ 


ИеШаге 801 2.10 | 

7 

1 V 00 N0 

В 

№ѵеІ 1 




Огасіе 8егѵег 1.0 | 

10 

| V 8п 0о РК 

в 

Огасіе | 

1 


| РК 00 N0 М 


301. Зегѵег 1.1 

10 

і V 8п Эо РК N0 

с 

Місгозо^І: 


і ИѴ ВІ РК 00 


801- Зегѵег 4.0 

10 

I V йо РК РК 00 

с 

ЗуЬазе 


і N0 І1Ѵ ВІ 


ЗОЬВазе 4.0.1 

10 

1 V 8п РК 00 N0 

в 

биріа ТесЬпоІодіез | 


1 N7 


ѴІА/йРЕ 1.2.3, ѴІА | 

8 

і РК РК N0 ЛѴ 

в 

Іп^огтаііоп Зузіетзі 




ХйВ 2.30 

12- 

І V 8п 0о РК РК 

в 

ХйВ Зузіетз 


і ВІ 00 N0 ЬІѴ 



Язык программирования 

11 

С 

СоЬоІ, С, АззетЫег Вазіс, Разсаі 
БоЫгап, СоЬоІ, С 
С, СоЬоІ , Вазіс 
С 

Рогігап, СоЬоІ, С АззетЫег, Вазіс 
С, СоЬоІ, ѴІА 

РогТгап, СоЬоІ, С, АззетЫег, Разсаі 


1. В графе 9 приняты следующие 
сокращения : 

V (Ѵіеѵ^з) - представления 
пользователя; 

5п (ЗпарзЬоІз) - выборки; 

О (йотаіпз) - домены (области 
определения столбцов 
отношений); 


РК (Ргітагу Кеуз) - первичные 
ключи; 

N0 (Мезіесі Оиегіез) - 
рекурсивные запросы; 

ЬІѴ (№11 Ѵаіиез) - 
неопределенные величины; 

ВІ (Веі'егеЫіаІ Іпіедгііу) - 
целостность ссылок. 


2. В графе 10 приняты следующие 
сокращения : 

Е (ЕтЬесІсІесІ $01.) - встроенный 
ЗСИ; 

С (Саіі ІпІегРасе) - интерфейс 
вызова; 

В (ВоТЬ) - обе возможности. 
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Таблица сравнительных характеристик серверов (продолжение) 


Продукт/Версия/ 

Компания 

Внешний интерфейс 

Сетевая поддержка 


поддерживаемый данным 
сервером БД 

сетевые операци- 
онные системы 

| сетевые 
| прото- 
| колы 
1 

12 

13 

1 14 
| 

Ешргезз ВВВМЗ 4 

Ешргезз 431, Ешргезз 

ВЕС АВ МРЗ ВР5 

І ТСР/ІР 

Ешргезз ЗоТТиаге 

Верогі Мгііег, Іпіег- 


1 


асТіѵе 501. 


1 

МеТМаге 501. 2.10 

501. Рі Іе, ВаЗОІ., Х0І_, 

N N386 

| ІРХ/5РХ 

Моѵеі 1 

ХШеѵе РІ из, В&В, 


1 


Оиіскзі Іѵег, ОВХІ., 


1 


Аірба 4, І.оі:из 



Огасіе Зегѵег 1.0 

Рго*С, $С!1-*Рогтз, 

N N386 І.М 1.5 В 

| ТСР/ІР, N311)6(1 Рірез 

Огасіе 

501_*Керогі:игіі:ег, 

ВЕС АЗ 

| ИеШОЗ 


301.*Мепи,501-*Р1и5, 




Огасіе, Оиіскзі Іѵег/ 




бВХЬ Тог Огасіе, 


1 


ѵІѴАСС, ЗАМ, оТбегз 


1 

501. Зегѵег 1.1 

ВаТаЕазе, Рагасіох 3.5, 

N N386 І.М 1.5 NР 

I ТСР/ІР, N 81116(1 Рірез 

МісгозоТТ 

АЗѵапсесІ ВеѵеіаТіоп, 

ВЕС 

1 


тсІЬз ОЬіесТ/1, Ѵіпгапі: 


1 


ВА5ІС, ВаТаміг ВВ50І., 


1 


оТбегз 



501. Зегѵег 4.0 

І-ОТиз 123, МісгозоТТ 

N N386 І.М 1.8 ВЕС 

| МатесІ Рірез 

Зубазе 

Ехсеі, АРТ Могкбепсб, 


і 


ШСС. ЗАМ 


і 

501-Вазе 4.0.1 

ЗОЬМі псіоѵ/з, 21 М, сІВХІ, 

N N386 1-М 1.5 В 5 

ТСР/ІР, Nате<1 Рірез 

Сирта Тесбпоіодіез 

Оиіскзі Іѵег, Сііррег, 

35 3+ М3 

1 МеТВІОЗ 


ЗАМ/ОВі , МОМАО, 301 


1 


СоттапЗег, 501. 


1 

ѴІА/ОВЕ 1.2.3, ѴІА 

ѴІА/С001-, ЯРІ./В, ХІ+, 

N N386 І.М 1.5 В 

| ТСР/ІР, Матей Рірез, 

ІпТогшаТіоп ЗузТетз 

Сазенюгкз-РМ.С 

NР Т 

1 МеіВІ 05 


іапдиаде Тооіз 



ХВВ 2.30 

В&В ВерогТ МгіТег, 

N N386 NР 

1 N618105. ІРХ/5Х 

ХВВ ЗузТетз 

ЗОВ.ЗАМ.ХОВ-ЗОІ., 


1 


РгееТогш, ХВВ-Огарб 


1 


N - ИеТ Маге; 

N386 - N61: Маге 386; 
N1:8 - Ые<: ВІОЗ; 

І.М - Мападег; 

1.3 - ІВМ ЦМ Зегѵег; 


В графе 13 приняты следующие сокращения ; 


В - Вапуап; 

ВЕС - ОЕСИеІ: : 

35 - ЗЗбаге; 

3+ - 3 РІ из Ореп; 
51. - 5і:аг (^N 1 
АЗ - Арріезбаге; 


АТ - Аррі е Та I к; 

Т - Т0Р5; 

АВ - Ароі Іо Яіпд; 

NРЗ - №{Могк РПе ЗузТет; 
М3 - МЗ^еТ. 
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По мнению зарубежных экспертов [3] 8(}Ь-серверы 
баз данных являются новейшим и потенциально са- 
мым мощным приложением для сетевой обработки 
данных. На сегодня рынок программных продуктов 
серверов баз данных не очень велик, но по прогноз- 
ным оценкам специалистов в ближайшие пять лет 
количество реализованных пакетов может возрасти в 
45 раз, а прибыли от их реализации — более чем в 
100 раз. 

Операционная среда сервера 

Под операционной средой сервера базы данных мы 
понимаем возможности операционных систем компью- 
теров и сетевых ОС. Каждый сервер базы данных мо- 
жет работать на определенных типах компьютеров и 
сетей (все типы сетевых ОС и протоколов, поддержи- 
ваемых конкретным сервером базы данных, приведены 
в таблице сравнительных характеристик серверов. 
Операционными системами серверов могут быть 008, 
08/2, Хепіх, Ііпіх а также ЬеС ѴМ8. Рабочие 
станции пользователей обычно работают под управле- 
нием 008, 08/2, Хепіх или Шіх. Существуют также 
возможности смешанного использования различных 
операционных систем. Выбор наиболее подходящей 
операционной системы необходимо делать с учетом 
многих факторов, включая стандарты, используемые в 
организации, предполагаемые объемы данных и вы- 
числений, принимая во внимание перспективы совер- 
шенствования и расширения системы. 

Выбор локальной вычислительной сети для сервера 
базы данных производится также по комплексным 
критериям. Серверы баз данных БС^ЬВазе (Сиріа 
ТесЬпоІояу), ХОВ (8оГЬѵаге ХОВ 0ВМ8) и ѴІА/ОКЕ 
(ІпГогтаііоп 8узіет$) работают под управлением 008 
и 08/2 и поддерживают сетевой протокол Ые(ВІ08. 
Сервер ХОВ работает кроме того под управлением не- 
которых типов ОС Ііпіх. При установке на сервере 
операционной системы ІВМ 08/2 Ехіепдесі ЕёИіоп ра- 
бочие станции клиентов могут использовать как 008, 
так и 08/2. Эта ОС интегрируется с сетевым серве- 
ром фирмы ІВМ и использует протокол 08/2 Ехіеп- 
бесі ЕсШіоп Сопнпііпісаііоп Мапа^ег. Сервер 8(}Ь 8егѵег 
(МісгозоН/8уЬазе) требует 08 /2 для сервера и под- 
держивает рабочие станции клиентов на базе 008 и 
08/2. Ему требуется поддержка Ыашесі Рірез и других 
сетевых функций управления прикладного програм- 
много интерфейса (ЬАЫ Мапа^ег АРІ). Поскольку 8<2Ь 
8егѵег является одновременно и продуктом фирмы 8у- 
Ъазе, его пользователи могут переходить к Ііпіх или 
ѴМ8, которые фирма 8уЬазе поддерживает без изме- 
нения прикладных кодов. 

Сервер ЫеІАѵаге 8(}Ь (Ыоѵеіі) работает как ѴАР 
(Ѵаіие Асісіегі Ргосезз), под управлением Ыоѵеіі Ыеі- 
АѴаге или ЫЬР (ЫеЬѵогк ЬоасІаЫе Мосіиіе — сетевой 
загрузочный модуль), в сети Ыеі^аге 386 и использует 
систему управления транзакциями ТТ8 (Тгапзасііоп 
Тгаскіпя 8узІеш). 


Сервер базы данных фирмы Огасіе (Огасіе 8егѵег) 
поддерживает ЫЕТВІ08, ІР8/8РХ и Вапуап Ѵіпез. 

В целом, при разработке систем прежде всего необ- 
ходимо оценить будущие прикладные задачи системы, 
а затем искать оптимальную операционную систему и 
сетевую конфигурацию. 

Использование языка $0Ь 

Большинство серверов баз данных поддерживает 
полный набор команд языка 8<2Ц который соответ- 
ствует либо стандарту АЫ8І, либо стандарту ІВМ. Кро- 
ме того, они обычно включают определенные расши- 
рения стандарта 8(}Ь. Например, сервер ХОВ сов- 
местим с 8(2Ь СУБД ОВ2 фирмы ІВМ. Сервер ХОВ 
очень близко подходит к архитектуре вложенного язы- 
ка 8(ЗЬ фирмы ІВМ. 

Ряд программных продуктов поддерживают специ- 
альные типы данных и функций. БС^Ь-продукты, реа- 
лизующие ядро СУБД в Іп^гез, Ешргезз иДпІегЬазе, 
позволяют разработчикам определять собственные 
функции, используемые вместе с БС^Ь-командами по- 
добно любым другим 8(2Ь-функциям. Интеллектуаль- 
ная база данных Іп^гез (версия 6.3) имеет средства, 
позволяющие определять новые типы данных и опера- 
торов. СУБД ХОВ и Огасіе обрабатывают рекурсивные 
запросы. 

Большая часть 8(2Ь-серверов (ядро) может хранить 
описания базы данных в системном каталоге. Этот ка- 
талог обычно бывает доступен пользователю — для об- 
ращения к нему используются те же 8(}Е-запросы. 
Информация, хранящаяся в каталоге имеет чрезвы- 
чайно важное значение. Обычно там хранятся описа- 
ния таблиц, колонок, индексов колонок и имена физи- 
ческих файлов. Некоторые каталоги хранят статисти- 
ческую информацию о таблицах — число строк, наи- 
большие и наименьшие значения в колонках. Систем- 
ный каталог поддерживает данные, которые админис- 
тратор может использовать при восстановлении систе- 
мы. 

Реляционные СУБД могут также использовать эту 
информацию для оптимизации 8(2Ь-запросов. Однако 
эти данные поддерживаются не всеми СУБД. Приме- 
ром может послужить, в частности, Огасіе — одна из 
реляционных СУБД, не имеющих средств хранения в 
каталоге статистической информации. 

Управление транзакциями 

СУБД должна поддерживать целостность базы дан- 
ных при выполнении транзакций. 8(}Ь-серверы осо- 
бенно мощны в реализации этого требования. Транз- 
акция — это набор команд работы с базой данных, ко- 
торый выполняется каждый раз при решении опреде- 
ленной задачи. Обычно при выполнении транзакции 
обновляется несколько таблиц и индексов, связанных с 
этими таблицами. 
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Для того, чтобы гарантировать синхронизацию 
обновления и целостность данных, в серверах обычно 
используют принцип “все или ничего* 4 , то есть либо 
вносят все обновления транзакции в базу данных, либо 
не вносят ни одного из них. Это происходит 
следующим образом. Обработка транзакции 
начинается после получения команды “начало 
транзакции**. Некоторые системы используют спе- 
циальную команду, другие воспринимают в качестве 
неявной команды начало программы. Завершает 
транзакцию команда 8(}Ь Соттіі, она и служит сиг- 
налом серверу базы данных о том, что все полученные 
изменения могут быть внесены в базу данных. Если 
же в процессе обработки транзакции произошел сбой, 
то все изменения транзакции автоматически игнориру- 
ются, а база данных сохраняется в неизменном состоя- 
нии. 

Управление транзакциями включает также такие 
важные элементы как автоматическая блокировка дан- 
ных на время внесения изменений и определение со- 
стояний взаимоблокировки. Блокировка (Ьоскіп^) 
предотвращает одновременное обновление данных не- 
сколькими пользователями. Некоторые серверы требу- 
ют явного указания операторов блокировки в тексте 
транзакции, но автоматическая блокировка предпочти- 
тельнее. Блокировать (в зависимости от типа системы) 
можно отдельные записи, страницы или только всю 
таблицу. Страницы представляют собой физические 
блоки, размеры которых варьируются от 1 до 4 Кбайт 
и включают несколько записей. Блокировка на уровне 
записи обеспечивает наивысший уровень параллелиз- 
ма. Блокировка на уровне таблицы позволяет в каж- 
дый момент времени обновлять таблицу только одному 
пользователю. Блокировка на уровне страницы нахо- 
дится где-то посередине. Большинство серверов реали- 
зуют блокировку на уровне записи или страницы. 
Единственной реляционной СУБД, которая предостав- 
ляет возможности для динамического выбора уровня 
блокировки между уровнем записи и уровнем таблицы 
является СУБД ІпГогтіх-ОпІіпе. 

Серверы базы данных должны автоматически опре- 
делять состояние взаимоблокировки (беабіоск). Это 
состояние возникает тогда, когда программа А читает 
запись, которая заблокирована программой В, а прог- 
рамма В читает другую запись, которая заблокирована 
программой А. Каждая из программ в этом случае бу- 
дет ожидать завершения другой. Следовательно, обе 
программы окажутся в состоянии взаимного ожидания, 
которое и называется взаимоблокировкой. Сервер базы 
данных должен выявлять подобные состояния и авто- 
матически прерывать выполнение одной из транзак- 
ций, выводя тем самым другую из вечного ожидания. 
Прерванная транзакция после исключения возможнос- 
ти ее блокировки будет выполнена сначала. В некото- 
рых системах отработка подобных ситуаций выполня- 
ется автоматически, в других требуется определенный 
опыт программирования, поскольку при определении 
состояния взаимной блокировки программы будут вы- 
полнены повторно сначала. 


Восстановление базы данных 

Возможности восстановления базы данных являются 
критическим фактором в выборе сервера. При возник- 
новении сбоя в системе или порчи информации на 
диске данные, не записанные физически в резервной 
копии базы данных, могут быть восстановлены из сис- 
темных буферов. А чтобы гарантировать, что ни одно 
из этих данных не пропадет, сервер базы данных дол- 
жен поддерживать специальный текущий файл регист- 
рации всех прошедших транзакций. 

В случае выхода из строя системы или жесткого 
диска, обычная процедура состоит в том, чтобы пере- 
записать базу данных с резервной копии. Но в таком 
случае теряются все обновления, которые прошли с 
момента создания резервного файла вплоть до выхода 
из строя жесткого диска. Сервер базы данных должен 
поэтому иметь специальные утилиты, позволяющие 
считывать текущий файл регистрации транзакций и 
восстанавливать их. Такие процедуры восстановления 
носят название “К.ОІ1 Ропѵагб**. Сервер ІВМ ОаІаЬазе 
Мапа^ег 08/2 Ехіепбеб Ебйіоп на сегодня единствен- 
ный из пакетов, не имеющий подобной процедуры. 

Некоторые серверы баз данных имеют так называе- 
мый “терпимый к сбоям** режим работы (ГаиІЫоІегапі 
ргосе$$іп&), сущность которого состоит в следующем. 
Две системы ведут одновременно две копии одних и 
тех же данных. Если одна из систем выходит из строя, 
то другая продолжает работать, сохраняя целостность 
базы данных. Метод крайне дорогостоящий, но в неко- 
торых приложениях (работающих в реальном време- 
ни) без подобных издержек просто не обойтись. 

Оба названных метода поддерживают программные 
продукты Іп^гезз, 8<2Ь 8егѵег, 8^Ь Вазе и ІпГогшіх-Оп- 
Ііпе. 


Целостность данных 

СУБД должны обеспечивать выполнение правил це- 
лостности или взаимной согласованности данных, 
включая целостность объектов, ссылок и реализацию 
правил, вводимых пользователем. 

Целостность объектов предполагает уникальность 
каждой записи в таблице. Чтобы обеспечить целост- 
ность объектов, в таблице выделяется поле (или груп- 
па полей), значение которого всегда должно быть оп- 
ределено, значение этого поля (полей) однозначно оп- 
ределяет запись и называется ключом. 

Целостность ссылок гарантирует согласованность 
значений полей в нескольких реляционных таблицах. 
Непосредственно (с помощью оператора языка 8(}Ь 
СКЕАТЕ ТАВЬЕ наподобие используемого в ЦВ2) 
поддерживает целостность ссылок сервер фирмы ІВМ 
ЦаіаЬазе Мапа^ег 08/2 Ехіепбеб ЕсШіоп. Этот ва- 
риант наиболее предпочтителен. Сервер ХЦВ фирмы 
ХЭВ 8узіешз позволяет пользователям определять вза- 
имосвязь ссылок с помощью команды языка 8(^1. 
АЬТЕКТАВЬЕ. В 8(2Ь 8егѵег фирмы 8уЬазе и СУБД 
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СЕРВЕРЫ БАЗ ДАННЫХ 


Іп^гез используются т.н. триггеры. Триггеры представ- 
ляют собой процедуры, которые автоматически выпол- 
няются перед каждым обновлением базы данных. Ад- 
министратор базы данных может выполнять триггеры 
на сервере базы данных. 

Взаимодействие серверов 

На больших предприятиях может возникнуть необ- 
ходимость в организации взаимодействия между нес- 
колькими серверами или их совместной работы с боль- 
шими и мини-ЭВМ. Соединяя системы вместе, следует 
выбрать одну из альтернатив: либо организовать прос- 
тейший вариант обмена данными между компьютера- 
ми и выбрать способ загрузки данных в главную ЭВМ, 
либо пытаться эмулировать работу распределенной ба- 
зы данных. С точки зрения пользователя в распреде- 
ленных базах данных несколько серверов работают 
“прозрачно", т.е. как один очень большой сервер. У 
администратора же базы данных появляется возмож- 
ность более равномерно распределять загрузку мощ- 
ностей, в то время как вся информация остается дос- 
тупной пользователям, работающим на нескольких ра- 
бочих станциях. Некоторые СУБД позволяют выпол- 
нять только поиск информации в таких системах, дру- 
гие поддерживают полное распределенное обновление. 
Примером реляционной СУБД, полностью поддержи- 
вающей распределенную базу данных, может служить 
сервер ѴІА/ЕЖЕ. 

Другой аспект взаимодействия — это взаимодейст- 
вие программного обеспечения, обеспечивающее прог- 
раммам доступ к удаленным базам данных на основе 
модели реег-1о.-реег. Такие программы обычно исполь- 
зуют специальный протокол АРРС (Абѵапсеб- 
ргоегатш-іо-рго^гатт-сотшипісаііоп) фирмы ІВМ. 
Используя АРРС, программы могут выполнять боль- 
шую часть своей работы в локальной сети, сохраняя 
средства доступа к ограниченным наборам данных на 
больших или мини-ЭВМ. Этот сценарий обычно реа- 
лизуется, когда сетевые прикладные программы нуж- 
даются в обновлении или поиске записей, хранящихся 
в базе данных большой ЭВМ. Протокол АРРС исполь- 
зуется, например, в пакете 8(21ЛЯеІ, который фирма 
Сиріа ТесЬпоІову разработала для обеспечения сов- 
местимости своего сервера 8(21. Вазе с СУБД ПВ2 
фирмы ІВМ. МісгозоН также с помощью АРРС 
недавно внедрила “связку" для своего сервера базы 
данных 8(21. 8егѵег и СУБД ОВ2. 

Управление ресурсами 

У серверов баз данных очень широк диапазон ре- 
сурсов, которые они потребляют, и требований по их 
управлению. Программы серверов баз данных, ориен- 
тированных на большие и мини-ЭВМ, не соответству- 
ют продуктам для ПЭВМ. Серверы, адаптированные с 
больших ЭВМ, могут иметь также поддержку файло- 


вых форматов для ПЭВМ и адекватные возможности 
импорта/экспорта файлов ПЭВМ. Ограничения по 
требованиям к памяти на каждого пользователя у сер- 
веров могут варьироваться от 30 до 500 Кбайт, при 
наличии внешних систем требования могут быть еще 
более широкими. 

Серверы баз данных используют разные форматы 
хранения данных: некоторые из них хранят записи 
произвольной длины, другие — только фиксированной 
длины. Это ведет к большим различиям в требованиях 
к дисковой памяти. Одни серверы автоматически мо- 
гут вновь использовать пространство памяти, занятое 
удаленными записями, другие могут требовать для 
этого выполнения специальных утилит. 

Наиболее совершенные серверы имеют специальные 
утилиты настройки и мониторинга базы данных, поз- 
воляющие оптимизировать производительность работы. 

Серверы могут также поддерживать команды языка 
8(21- СКАЫТ и К.ЕѴОКЕ, которые обеспечивают без- 
опасность базы данных. 

Для эффективной работы с серверами баз данных, в 
силу их достаточно высокой сложности, требуются ад- 
министраторы, хорошо ориентирующиеся в вопросах 
управления данными. Поэтому вопросы обучения и 
подготовки персонала играют здесь далеко не послед- 
нюю роль. 

Поддержка внешних 
прикладных программ 

Серверы баз данных рассчитаны на поддержку 
большого количества различных типов приложений, и 
разработчики нуждаются в инструментальных средст- 
вах для их использования. Поэтому следует особо ос- 
тановиться на прикладных разработках и инструмен- 
тальных средствах, появляющихся на рынке вместе с 
серверами. 

В зависимости от своих прикладных задач, пользо- 
ватели могут нуждаться в различных типах инстру- 
ментальных средств для реализации интерфейса с ба- 
зой данных: объектно-ориентированные средства, 

электронные таблицы, текстовые процессоры, графи- 
ческие пакеты, настольные издательства и другие. 
Пользователю могут быть также необходимы специ- 
альные инструментальные средства, которые нужны 
при разработке сложных программ, требующих приме- 
нения экспертных систем или других программ искус- 
ственного интеллекта. 

Организация пользователя может уже иметь боль- 
шой опыт работы с однопользовательскими СУБД, та- 
кими как 6ВА8Е, ОаІаЕазе, Рагабох, Веѵеіаііоп или 
совместимыми с 6ВА8Е, так называемыми “клонами", 
6ВХЦ Сііррег или РохЬазе. Если пользователь заинте- 
ресован в сохранении своих затрат на эти продукты, 
необходимо выбрать сервер, который поддерживает 
данную СУБД. Необходимо также проанализировать 
вопросы переносимости и производительности. У та- 
ких продуктов как Рагабох (зеі-огіепіес! — ориентиро- 
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ванных на группы записей), возможно, в среде 
сервера базы данных сохранится высокая про- 
изводительность. В то же время, у продуктов, 
подобных сШАЗЕ (гесогсі-аі-а-ііте — ориенти- 
рованных на отдельные записи) характе- 
ристики производительности могут ухудшить- 
ся. 

В настоящее время разрабатывается много 
новых внешних пакетов, имеющих развитый 
графический интерфейс. Повышение 
производительности программирования в них 
достигается за счет использования объектно- 
ориентированной техники и языка 8(}Ь для 
увеличения продуктивности программирования 
в многооконной среде. Программные продукты 
ОЬцесі/1, Арріісаііоп Мапа^ег, Ассезз и 

5(2Ь ^іпсіодѵз открывают возможности 
разработки оконных приложений для широкого 
круга 8(}Ь-серверов баз данных. 


Л. Проничева 

По материалам: 

1. К. ЛѴаііегзоп ЗегѵегТесНпоІову: Ціѵіёе іо 
Соп^иег. Цаіа Вазесі Абѵізог. МагсН 1989. р.92- 
100 . 

2. ЦВМ8 Ма^ахіпе'з ЦаіаЪазе Виуег'з Сиіёе 
апб Цігесіогу. Ѵоі. 3. ЫитЬег 6. 1990. р.43-54. 

3. Оаіатаііоп'з Ргосіисі Сиісіе. Цаіатаііоп. 
ОсіоЬег 15. 1990. р.84-86. 

4. І.Вигтягб. ЗДІІ 8Ьо>ѵ: ТНе Рігзі Аппиаі 
Сиріа Эеѵеіорегз Сопіегепсе. Цаіа Вазесі 
Абѵізог. ЫоѵешЬег 1990. р.115-116. 

5. .ГМоасі. \ѴЬаі ІВМ 8ауз АЬоиі С1іепі/8егѵег. 
Оаіашаііоп. РеЬгиагу 1 1991. р.54-57. 



В первый день выставки Сопкіех 
фирма Арріе произвела большой 
фурор, продемонстрировав новые 
серии рабочих станций (}иа(Іга 700 и 
900, новое поколение портативных 
машин и новый Мае Сіаззіс II. 

Для поддержки новых машин бы- 
ла выпущена следующая версия 
ОС — ѵ.7.01. Она требует 2 Мбайта 
ОЗУ и жесткий диск. Фирма заяв- 
ляет, что новая версия — это не 
замена 8у$іет 7.0, а просто ее 
модификация» для новых машин. 

Настольная станция Оиасіга 700 
выпускается в четырех конфи- 
гурациях — одна только с флоппи- 
диском, остальные с винчестерами 
разной емкости. (}иа(іга 900 в 
корпусе типа и Юшег м также имеет 
одну бездисковую конфигурацию и 


две дисковых. Цены на станции ле- 
жат в диапазоне 3,499-9,199 дол- 
ларов. 

Обе системы выполнены на про- 
цессоре 68040, работают втрое быст- 
рее Мае Шх, имеют улучшенный 
цветной монитор, поддержку ЕіЬег- 
пеі и новую технологию контролле- 
ров диска 8С8І/МиЬиз. Кроме этого, 
напольная (}иа(Іга 900 может иметь 
до 64 Мбайт оперативной памяти, 
дополнительные жесткие диски или 
другие устройства, подключаемые к 
интерфейсу 8С8І. 

Пользователи МасішозН Нсх и ІІсі 
могут купить небольшую логическую 
схему, которая монтируется на плате 
и превращает их компьютер в стан- 
цию (^иасіга 700. Каждая такая пла- 
та имеет 4 Мбайт оперативной памя- 


ти и 512 Кбайт памяти с батарейкой. 

Новые портативные машины — 
РошегЬоок 100, 140 и 170 — постав- 
ляются с 2 Мбайтами ОЗУ (расши- 
ряется до 8 Мбайт) и 20- либо 40- 
мегабайтным жестким диском. Цена 
находится в диапазоне от 2,299 до 
4,599 долларов. 

Новый Мае Сіаззіс II превосходит 
старый Сіаззіс в производительности 
и поддержке виртуальной памяти 
благодаря использованию процессора 
68030 с тактовой частотой 16 МГц, 
который вдвое быстрее использовав- 
шегося ранее. Еще одной добавкой к 
Сіаззіс является возможность ввода 
звукового сигнала. 

НекзЬуІе$ Аеия ІУеЬѵогк, 21 
ОсІоЬег 1991 
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МУЛЬТИМЕДИА — СИНТЕЗ ТРЕХ СТИХИЙ 



Это заключительная часть статьи 
по системам мультимедиа 
(см. КомпьютерПресс №№ 7,8' 91), 
посвященная перспективам этой 
технологии в нашей стране. 


Мультимедиа - 
синтез трех стихий 


А что у нас? 

Теперь, ознакомившись с положением дел в области 
мультимедиа за рубежом, вернемся домой и оглянемся 
вокруг. Мы увидим, что системы мультимедиа, этот 
качественно новый инструмент познания, обучения, 
общения, которым уже 4 года пользуются школьники 
Англии, который быстро внедряется во все сферы дея- 
тельности и в быт в цивилизованном мире, — у нас 
остается практически неизвестным, по каким-то непо- 
нятным причинам выпав из поля зрения и средств 
массовой информации, и разнообразных ведомств. Ве- 
домства занимаются компьютеризацией школ, пытаясь 
оснащать их — в 1991 году! — устаревшими еще до 
рождения КУ ВТ-86 и Корветами, способными, в силу 
своей ненадежности и “недружественности", привить 
лишь отвращение и страх перед компьютерами. Меж- 
ду тем в мире уже выросло “информатизированное" 
поколение, для которого сети общего пользования, 
системы типа телетекста и видеоданных, электронная 
почта и компьютеры стали естественным, непремен- 
ным атрибутом окружающей жизни как в профессио- 
нальной деятельности, так и дома. Это не кажется 
страшным, если рассматривать отдельно взятого наше- 
го человека: если “окунуть" его в эту среду, он, быст- 
рее ли, медленнее ли, перестроит стиль мышления, 
научится управляться с этими информационными инс- 


трументами (для ребенка же вообще не будет проб- 
лем), однако в масштабах страны мы видим качест- 
венное отставание всего общества, всех его институ- 
тов, и это становится непоправимым. Появление и по- 
всеместное внедрение систем мультимедиа увеличива- 
ет скорость, с которой уходит от нас цивилизованный 
мир. 

Попробуем оценить перспективы, которые могут 
ожидать мультимедиа в нашей стране. Для этого по- 
смотрим, как обстояли дела в последние годы с вне- 
дрением других информационных технологий. Сразу 
оговорюсь, что все изложенное ниже — личные 
измышления автора, основанные, однако, на более чем 
пятнадцатилетием опыте барахтанья в неспешном по- 
токе развития отечественной вычислительной техники. 
Безусловно, постоянное сопоставление состояния дел 
“у нас" и "у них" не может не породить некоторого 
комплекса вечного несоответствия мировому уровню, 
опаздывания, повторного изобретения давно изобре- 
тенного, порой ощущения полной ненужности и бес- 
смысленности всех усилий. Утешала и поддерживала 
лишь аналогия с еще одной областью, поневоле близ- 
кой — стоматологией, отставшей, пожалуй, еще 
больше и безнадежней. Тем не менее, осознавая это 
отставание, наши стоматологи (слава богу!) продол- 
жали сверлить, пилить, лепить, придерживая 
заветный несточенный бор или щепотку цемента, 
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привезенную кем-нибудь из-за бугра» для особо 
доверенных клиентов. 

Грустная история 

Самый свежий пример — это история отечествен- 
ных персональных компьютеров. Большая ее часть 
происходила уже после объявления перестройки и 
ускорения, и сначала казалось, что ну уж теперь-то!.. 
По рукам ходили какие-то отксеренные аналитические 
записки и докладные из высоких сфер: массовые за- 
купки комплектующих и периферии, закупки заводов, 
совместные производства... И что же? Истинная ком- 
пьютеризация страны происходит лишь сейчас, с по- 
мощью бартерных закупок и сборочных СП, по совсем 
не персональным ценам и не благодаря, а вопреки 
усилиям министерств, которые смогли в результате 
многолетних и дорогостоящих усилий наводнить кла- 
довки, пространства на шкафах и под столами в тыся- 
чах учреждений и школ по всей стране пирамидами 
грязно-серо-черных неработающих, полуработающих, 
несовсем работающих — зато “чисто самодельных** 
Электроник, ДВК, Корветов, УКНЦ, Агатов и т.п. Как 
будто об этой “технике** писал анонимный адресант 
Генри Баскервиля: “Если вам дороги ваш рассудок и 
ваша жизнь, держитесь подальше от торфяных бо- 
лот. 

Подобное положение и с внедрением сетей: мини- 
стерствам связи европейских стран хватило в конце 
70-х годов по 3-4 года от первоначального проекта до 
введения в полномасштабную эксплуатацию обще- 
национальных сетей общего пользования. Появившие- 
ся примерно тогда же, не без оглядки на Запад, про- 
екты ОГСПД и Академсети, записанные во множество 
планов и постановлений и разрабатывавшиеся целыми 
институтами, так где-то и растворились в процессе ре- 
ализации. Тут, безусловно, значительная часть про- 
блемы заключалась в отсутствии каналов связи, но это 
лишь подтверждает закономерность: нам при наличии 
супер-министерства связи (и еще МПСС в недавнем 
прошлом) осталось немного подождать, пока какое- 
нибудь из СП не обеспечит Москву, а потом и страну 
качественной сетью скоростных связных трактов 
(такие проекты уже есть), другое поставит узлы и не- 
обходимый софтвер — и сеть готова. Сейчас такой 
процесс быстро проходит на территории бывшей 
ГДР — и она включается в мировую “инфосферу**. 

Пожалуй, еще более показательна ситуация с ло- 
кальными сетями: для них не нужны ни дорогие 
тракты — достаточно мотка дешевого кабеля или даже 
скрученной пары проводов, ни высокая электронная 
технология, ни даже глубокие научные разработки: 
стандарты и протоколы давно опубликованы, проком- 
ментированы, описаны, методы их реализации и воз- 
никающие проблемы; казалось бы, есть все, чтобы 
организовать выпуск несложных сетевых контролле- 
ров, реализующих протоколы нижних уровней (для 
разных типов ЭВМ), приложить программные модули 
для верхних — и получить недорогую локальную сеть 


массового применения. Однако на практике в течение 
многих лет многие умельцы (без иронии!) во множе- 
стве контор параллельно создавали уникальные невос- 
производимые локальные сети из подручных 
средств — вплоть до крейтов КАМАК и шкафообраз- 
ных МПД ЕС ЭВМ. Это приводило к колоссальным 
затратам сил, средств, причем часто впустую: очень 
многие разработки заглохли на разных этапах реали- 
зации в связи с непосильностью задачи, слишком 
большим временем разработки, отсутствием програм- 
много обеспечения или просто уходом основного 
умельца. Массовое же внедрение локальных сетей 
происходит лишь после снятия эмбарго, путем поста- 
вок из-за рубежа готовых комплектов сетей. 

Подобная ситуация может повториться и в разра- 
ботке средств мультимедиа. В связи с тем, что прак- 
тика уже требует внедрения каких-то элементов муль- 
тимедиа, а отечественная промышленность пока ни- 
чего предложить не может, вполне вероятна разра- 
ботка и изготовление “на коленке** единичных плат 
под конкретные применения. 

Итак, мы видим, что опыт развития вычислитель- 
ной техники в нашей стране на протяжении 80-х гхь 
дов показывает, что большинство программ провали^ 
ваются или реализуются недопустимо медленно при 
“изоляционистском** подходе к их выполнению. 
Исходя из этой закономерности, а также задавшись 
целью обеспечить возможность более быстрого внедре- 
ния мультимедиа и других новых технологий в^ СССР, 
а не многолетнее спокойное финансирование исследо- 
ваний их развития за рубежом, необходимо макси- 
мально ориентироваться на всевозможные совместные 
формы исследований, разработки и производства. 

Ближайшие перспективы 

Рассмотрим различные стороны деятельности по 
исследованию и развитию систем мультимедиа. 

1. Работы по отдельным теоретическим аспектам и 
отдельным компонентам мультимедиа. Они уже 
сравнительно давно проводятся в стране — это такие 
направления, как технология гипертекста, базы дан- 
ных, обработка изображений, звука, комплексные 
инструментальные системы, графические и анимаци- 
онные средства. Существуют некоторые наработки и 
опыт работы в этих областях. Однако они разроз- 
нены, их приложение к “истинным** системам муль- 
тимедиа, интеграция в единую систему мультимедиа 
затруднены как отсутствием адекватных технических 
средств, так и недостаточной координацией этих 
исследований именно под углом зрения мультимедиа. 
Тем не менее деятельность по разработке техни- 
ческих и программных средств синхронизации, за- 
хвата и обработки изображения, работы со звуко- 
выми данными, стыковки компьютера с аналоговыми 
устройствами весьма перспективна в наших усло- 
виях. Спрос на подобные средства уже велик, отече- 
ственный рынок же почти пуст. Причем на доступ- 
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ной элементной базе наши разработчики и програм- 
мисты вполне могут создавать продукты, не уступа- 
ющие зарубежным аналогам. Один из примеров — 
разработанный малым предприятием “Софт-Хард 
Технология 44 цветной видеодигитайзер для ІВМ-со- 
вместимых компьютеров, работающий в реальном 
времени и обеспечивающий разрешение 832x600 
пикселов при 19 битах под цвет пиксела. Плата ви- 
деодигитайзера поставляется с пакетом программной 
поддержки, обеспечивающим работу с ней из языков 
Си и Паскаль. 

2. Разработка и реализация алгоритмов сжатия 
информации. Основной прогресс в развитии цифро- 
вых систем мультимедиа в последнее время обеспе- 
чен развитием и реализацией алгоритмов сжатия. В 
части разработки алгоритмов дела в СССР могут 
оказаться неплохи — методы сжатия изображений 
наверняка применялись в космической и военной 
технике и сейчас, в рамках конверсии, они могут 
быть приоткрыты и запатентованы; кроме того, ко- 
дировщики и математики могут разработать новые 
алгоритмы или заняться улучшением, дальнейшим 
усовершенствованием публикуемых алгоритмов ІРЕС 
и МРЕС. Проблемы возникнут, однако, при реализа- 
ции разработанных алгоритмов. Здесь сильно ме- 
шают отсутствие необходимой технологии и инерци- 
онность промышленности. Нам не под силу, подобно 
маленькой фирме С-СиЬе Місгозузіет, разработать 
СБИС-микросхему, реализующую алгоритм сжатия и 
сравнимую по сложности с 80386, наладить ее про- 
мышленный выпуск, разработать и также запустить 
в производство плату расширения на основе этой 
микросхемы, “одеть 44 все это софтвером и в ре- 
зультате менее чем за год (!) получить общедоступ- 
ный коммерческий продукт, который любой пользо- 
ватель может установить на своем компьютере. 
Можно рассчитывать только на не столь эффектив- 
ные программные реализации, в лучшем случае — 
малосерийные платы на дискретных элементах. 

Если думать о перспективе выпуска плат мультиме- 
диа у нас в стране, то возможен вариант частичной 
реализации алгоритма сжатия на кристалле, чтобы 
достичь уровня сложности схемы, посильной для на- 
шей технологии, остальная часть алгоритма реализу- 
ется программно, возможно, с занесением в КОМ. 
Другой путь — использование кІЗС-процессоров 
(которых, впрочем, тоже пока нет — но они по 
уровню сложности доступны нашей МЭП-техноло- 
гии). Лучший, быстрейший путь — это некая форма 
совместной деятельности с цивилизованной стра- 
ной — от закупки чужих чипов сжатия (их цена 
сейчас порядка 50-200 долларов) и производства на 
их основе собственных плат до патентования своих 
алгоритмов и выпуска реализующих их чипов за ру- 
бежом. 

3. Выбор политики в области технических средств. 

На первом этапе, этапе исследований и опытного 
внедрения мультимедиа, единственное приемлемое 
решение — закупка плат и устройств мультимедиа 


за рубежом. Здесь приходится задуматься над выбо- 
ром: какого стандарта мультимедиа следует 

придерживаться. 

Для начала приходится с сожалением признать, что 
в ближайшей перспективе выбор массового компью- 
тера практически сделан за нас — это линия ІВМ 
РС. Далее, среди многочисленных систем мультиме- 
диа для машин этой линии на начало 1991 года на- 
ибольшего внимания заслуживали два варианта: ОѴІ 
и новые продукты ІІѴС. Однако сейчас все большее 
количество фирм объявляет о своей поддержке алго- 
ритмов ЛРЕС и МРЕС. Наиболее желателен вариант 
приобретения 3-4 вариантов плат мультимедиа, а 
испытания проводить при реализации пунктов 4 и 5. 
В дальнейшем необходимо постоянно следить за ми- 
ровым рынком мультимедиа, за технической полити- 
кой ведущих фирм; при появлении перспективных 
(или общепризнанных) систем следует обеспечивать 
их закупку или получение на испытания. 
Тщательный, продуманный выбор между существу- 
ющими в мире стандартами и направлениями очень 
важен, чтобы не совершить ошибки, подобной вы- 
бору системы 8ЕСАМ в телевидении, не уйти в ту- 
пиковую ветвь, не создать еще один информацион- 
ный занавес от цивилизованного' мира и иметь воз- 
можность на выбранных технических средствах со- 
здавать продукты, имеющие спрос на мировом 
рынке. 

Не следует, однако, путать разные задачи. Сказан- 
ное выше относится главным образом к “массовому 44 
применению мультимедиа — в образовании и учреж- 
денческой деятельности. В то же время авторские 
программно-аппаратные комплексы для разработки 
СО-кОМ — электронных книг, руководств, других 
продуктов гипермедиа чаще создаются на базе Мас- 
іпІозН. Хорош этот компьютер и при подготовке, 
производстве и использовании интерактивных виде- 
одисков благодаря стекам Нурегсагб, позволяющим 
хранить ссылки на конкретные кадры аналогового 
видеоустройства, гибкой системе управления презен- 
тацией пакета Оігесіог, а также настольной системе 
записи и воспроизведения таких дисков, управляемой 
с МасіпІозН. Сейчас — наконец-то! — фирма Арріе 
выходит на наш рынок. Будем надеяться, что ей уда- 
стся нарушить сложившееся в стране необъяснимое, 
иррациональное засилье компьютеров линии ІВМ во 
всех сферах применения — даже в тех, где они зна- 
чительно проигрывают своим конкурентам, и что 
мультимедиа-системы на базе МасіпІозН станут 
одним из основных направлений этого наступления 
Арріе. 

Для систем настольных видеостудий может больше 
подойти Аілі^а либо, опять-таки, Мае. Для более 
сложных применений, с жесткими временными 
требованиями и большим' объемом вычислений, си- 
стему придется создавать на базе мощных рабочих 
станций типа Зші или к-6000 ІВМ. 

4. Разработка инструментальных средств мультимедиа, 
авторских систем. Уже отмечалось, что в этой обла- 
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сти требуются усилия разработчиков. Однако они мо- 
гут быть успешными, конкурентоспособными лишь в 
случае быстрого приобретения новых технических 
средств, для которых еще не сложился круг привыч- 
ного для пользователя инструментального софтвера; 
здесь можно пойти на прямой контакт с фирмой — 
производителем технических средств. Другая воз- 
можная “ниша“ — открыть какую-то новую сферу 
применения имеющихся технических, средств и со- 
здать специализированную авторскую систему для 
этой сферы. 

5. Разработка конечных продуктов мультимедиа раз- 
ных типов, а также методик их проектирования и 
изготовления. Это совершенно новый вид деятельно- 
сти, сочетающий черты программирования, разра- 
ботки игр, производства фильмов и др.; в СССР пока 
практически нет специалистов в этой области. По- 
мимо сложных задач интерактивного программиро- 
вания, управления информацией, навигации, возни- 
кают также проблемы: создания сценария, производ- 
ства видео-, фото- и аудио-материалов. Как правило, 
необходимо участие специалистов в предметной 
области, к которой относится создаваемый продукт. 
Некоторый опыт такой работы накоплен в Третья- 
ковской галерее. Русском музее, где уже в течение 
ряда лет ведутся работы (совместно с зарубежными 
фирмами) по занесению фондов на интерактивные 
видеодиски. 

Задачи 4 и 5 тесно взаимосвязаны: без опыта произ- 
водства продуктов мультимедиа трудно оценить сла- 
бости существующего авторского софтвера, прочув- 
ствовать тонкие места при работе с данной 
аппаратурой; создаваемую авторскую систему по- 
лезно испытывать и оценивать на разработке кон- 
кретного продукта. С другой стороны, иногда в про- 
цессе разработки большого продукта мультимедиа со- 
здается столько инструментальных и вспомогатель- 
ных программ, что их выпускают на рынок в каче- 
стве самостоятельного продукта. Так, в частности, 
поступила Вгііаппіса ЗоІКѵаге, которая вслед за вы- 
ходом Сотріоп МиШ-Мебіа Епсісіораесііа выпустила 
РиЫізЬег СО-КОМ Тооікіі. 

Работы по этим двум пунктам должны привести к 
появлению и внедрению первых отечественных про- 
дуктов мультимедиа. Однако здесь возникает серьез- 
ная проблема. 

6. Распространение и применение продуктов муль- 
тимедиа. Это — вопрос, наиболее критичный в 
СССР. Дело в том, что сегодня они просто не могут 
дойти от изготовителя до потребителя. В СССР нет 
ни СЭ-КОМ, ни оптических стираемых дисков, ни 
сменных винчестеров, ни ленточных устройств боль- 
шой емкости, ни скоростных сетей. На дискету 
1.44 Мбайт помещается около 10 секунд видео в 
сжатом формате ЦѴІ; передача такого же количества 
данных через телефонную сеть при очень оптими- 
стической скорости 4800 бод потребует полчаса; вы- 
деленные каналы побыстрее в 2-4 раза. Локальная 
сеть позволит передавать данные мультимедиа лишь 


в пределах одного учреждения. Полувыходы, пер- 
выми приходящие на ум: установка продукта на вин- 
честер пользователя разработчиком с помощью до- 
ставки имеющегося у разработчика внешнего нако- 
пителя с контроллером и подключения его к машине 
пользователя; путешествие разработчика со своим 
компьютером и локальной сетью к пользователю или 
наоборот; перекачка данных мультимедиа на боль- 
шую машину и запись на ее ленты, а затем распро- 
странение этих лент; при этом, однако, у поль- 
зователя также должна быть в досягаемости связка 
ПК — большой компьютер. 

Что касается производства внешних устройств боль- 
шой памяти, то здесь надеяться на нашу промыш- 
ленность, видимо, не приходится: за все годы разви- 
тия ЕС ЭВМ ей (как, впрочем, и болгарской) не 
удалось создать (скопировать) ни одного дискового 
магнитного устройства достаточного качества и на- 
дежности. Изготовление же оптических устройств, 
даже при допущении наших передовых позиций в 
лазерных делах, все равно упрется в больные про- 
блемы точной механики и малообъемной высокочи- 
стой химической технологии. 

Впрочем, я с радостью готов взять свои слова 
обратно, если кто-нибудь меня опровергнет. Так, ко 
мне в последний момент попала очень обнадежива- 
ющая бумага — рекламный листочек МНПП 
“КОМПАКТ" (г. Москва), объявляющий о выпуске 
этим предприятием и А/О “СИНКВЭС" (Таллинн) 
отечественных дисководов СЦ-КОМ, полностью соот- 
ветствующих международным стандартам, подключа- 
емых к ІВМ РС, работающих с МісгозоН СЦ-ЕхІеп- 
Ііоп и даже воспроизводящих аудиодиски. Постара- 
емся получить более подробную информацию об 
этой системе, возможно, испытать ее в действии — 
и о результатах сообщим читателям. 

Приобретение для пользователей дисководов СО- 
КОМ могло бы стать хорошим выходом, но при этом 
придется отсылать подготовленные продукты для ти- 
ражирования за рубеж, что достаточно накладно, 
особенно при малых сериях. Видимо, следует прояв- 
лять активность в направлении организации выпуска 
СО-КОМ дисков в нашей стране; такое производство 
может быть, в частности, организовано на базе 
фирмы “Мелодия", уже выпустившей первые лазер- 
ные аудиодиски. Возможно, какое-нибудь крупное 
издательство проявит интерес к этому очень пер- 
спективному направлению и создаст, например, СП 
по выпуску оптических и СО-КОМ дисков? Напо- 
мним, что рынок таких электронных изданий за ру- 
бежом достигает миллиардных отметок. 

(Здесь я должен извиниться перед читателями за до- 
пущенную мной в КомпьютерПресс 7'91 неточность: 
чистый диск СЦ-КОМ стоит несколько долларов, а 
чистый видеодиск — порядка 100-200 долларов.) 
Каковы же ближайшие практические перспективы 
разработчика конечных продуктов мультимедиа? Ви- 
димо, сначала придется ориентироваться на хорошо 
оснащенных пользователей, например показательные 
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* “пилотные" ліколы или учебные центры, или на еди- 
ничные применения типа тренажеров, “информаци- 
онных киосков" в музеях и т.п. Кроме того, следует 
обеспечить такие конфигурации закупаемых учебных 
комплексов, которые в будущем могли бы легко быть 
расширены в станции мультимедиа — установкой 
дополнительных плат или подключением внешних 
устройств либо даже просто добавлением программ. 

7. Наконец, главное в научном плане: исследование 
мультимедиа как составной части информационных 
технологий будущего, в комплексе всех связанных 
проблем; именно здесь существуют наилучшие воз- 
можности не копирования зарубежного опыта, а по- 
лучения оригинальных научных результатов, разви- 
тия своей линии в области мультимедиа. Однако для 
этого требуется закупка комплекса технических и 
программных средств для создания стартовых усло- 
вий, соответствующих передовому сегодняшнему 
уровню. 

Практические работы с системами мультимедиа (п.п. 
4,5) затронут предметы “более высокой теории" — 
построения ММ-баз, систем гипертекста и ги- 
перизображений, объектно-ориентированных сред и 
т.п., а также прикладные вопросы отдельных 
“медий": быстрая компьютерная графика и анима- 
ция, настольные видеостудии, компьютер и музыка, 
электронная и видеопочта, что с необходимостью 
приведет к активизации работ в этих крайне инте- 
ресных направлениях. Однако необходимо зани- 
маться и вопросами развития информационных си- 
стем в целом, их положения и роли в современном 
мире и в преобразовании этого мира. Для разработки 
этих фундаментальных вопросов было бы полезно 
отойти от ІВМ РС с их беспорядочно, бессистемно 
наращиваемым нагромождением хардвера и софтвера 
(например: БОЗ, над ним ДѴіпбоіѵз, над АУіпбоѵз 
ТооШоок, над ТооШоок перенесенный с Мае Сиібе, 
над Сиібе собственно продукт), и обратиться к ком- 
пьютеру ЫеХТ, который в наибольшей степени со- 
ответствует требованиям времени, поскольку задумы- 
вался и создавался именно как информационный ин- 
струмент завтрашнего дня, интегрируя последние до- 
стижения и теории, и технологии. 

О координации 

К сожалению, сведения об отечественных работах 
по мультимедиа получить труднее, чем о зарубежных. 
В общедоступной компьютерной периодике практичес- 
ки ничего не публикуется, специального издания нет. 
Поэтому пока исследователи в этой области довольно 
разобщены. 

Большие надежды мы возлагали на межотраслевую 
конференцию “Оптические дисковые информацион- 
ные системы", которую должны были провести в 
октябре 1991 года Минрадиопром и НИИ бытовой 
радиоэлектронной аппаратуры (г. Львов) — с очень 
интересным кругом рассматриваемых проблем. Она 
могла бы послужить началом объединения усилий 


разработчиков мультимедиа в СССР. Однако — 
увы — перенесена на неопределенный срок. 

Сведения о ряде конкретных отечественных разра- 
боток, дошедшие в виде слухов и частных сообщений, 
нуждаются в проверке, поэтому о них — в следующих 
номерах. 

В настоящее время предпринимаются усилия по со- 
зданию Цент{>а мультимедиа. Задачами Центра, поми- 
мо проведения собственных исследований в различных 
областях мультимедиа, являлись бы координация 
работ с другими организациями в области мультиме- 
диа, вовлечение их в работы по перечисленным выше 
пунктам, пропаганда технологии мультимедиа, обуче- 
ние и консультации по использованию имеющихся си- 
стем, инициирование исследований во вновь появля- 
ющихся перспективных направлениях. Возможно 
также издание бюллетеня или журнала по мультиме- 
диа и близким тематикам. 

Будем надеяться, что темпы проникновения муль- 
тимедиа в нашу страну увеличатся — и за счет появ- 
ления собственных разработок, и за счет более актив- 
ного выхода на наш рынок зарубежных фирм. Сейчас 
же либо за рубежом считают, что нам пока за глаза 
достаточно конторских ІВМ РС, либо какие-то эле- 
менты мультимедиа находятся под контролем КОКОМ 
как элементы новейших технологий — во всяком слу- 
чае, на проходящие в стране выставки образцы муль- 
тимедиа-продукции почти не попадают. Поэтому пока 
приходится, довольствоваться сведениями из зарубеж- 
ной периодики, пытаться получить понятие о целом 
на основе чьих-то обрывочных впечатлений, иными 
словами “ощупывать хвост слона", а затем убеждать 
всех, что слон длинный и тонкий как змея — что я и 
постарался сделать в этом обзоре. 

С. Новосельцев 
Сетевой адрес 
пехі@іріап 15. іріап. тзк. $и 


МісговоИ сделала русский МЗ-БОЗ 5.0. Это третий 
русскоязычный продукт, выпущенный фирмой. 

Система, по утверждению разработчиков, работает 
лучше предыдущей версии. В ней используется перера- 
ботанный пользовательский интерфейс, многочислен- 
ные подсказки — все на русском языке. 

Кроме того, система имеет встроенные утилиты вос- 
становления удаленного файла и почти многозадачный 
режим. Существенно улучшена поддержка принтеров, 
не имеющих прошитых русских букв. Система будет 
поддерживать как русский, так и украинский и бело- 
русский языки. 

Продаваться русский МЗ-БОЗ будет только в ком- 
плекте с компьютерами. Это политика фирмы, которая 
хочет получить хоть какие-то гарантированные прибы- 
ли на советском рынке. 

А еще у фирмы появился новый дистрибьютор в Ки- 
еве — НПП Гамма, имеющий офис на Крещатике. 

Сейчас Зіееріег Иб. из Москвы в экспериментальном 
порядке (до конца года) продает русскоязычный М3 
>Ѵогкз за рубли — 9500 рублей. 

ЫеѵпЬуіез Ыею НеЪюгк, 7 ОсІоЬег 1991 
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Между прочим 


Ѵепіига и Раіп(Вги$Ь: маленькие хитрости 

Графический редактор РаіпШгиаН IV Ріиа позволяет ре- 
шить некоторые проблемы, возникающие при работе с паке- 
том Ѵепіига РиЫіаНег 2.0. 

При распечатке вентуровской графики (рамки, скруглен- 
ные рамки и эллипсы) с серым фоном на принтерах, эмули- 
рующих Ьааегіеі (проверено на С.ПЧЖ ІЛР8 10 и на КІССЖ 
РС1А5ЕК 6000), нередко возникают светлые или темные по- 
лосы вместо равномерного тона. Избавиться от этого дефекта 
можно, заменив вентуровскую графику, созданную в редакто- 
ре РаіпШгиаН ГѴ Ріиа с использованием другого способа пред- 
ставления полутонов серого цвета (способа образования раст- 
ра). Суть этих замен и превращений в том, чтобы получить 
возможность выбирать сам способ, частоту растра (ЬРІ) и яр- 
кость по своему усмотрению. Для работы, кроме Ѵепіига РиЪ- 
ІіаНег, нужен РаіпШгиаН в двух конфигурациях — на 16 цве- 
тов и черно-белая. 

Подробная последовательность действий такова: 

- создать в “вентуре* на чистой странице графический 
элемент без фона (или скопировать на чистую страницу 
элемент со сверстанной страницы и выключить фон) ; 

- распечатать страницу с этим графическим элементом в 
файл. При этом в меню “Сервис*/“Параметры принтера* 
должен быть выбран принтер Ьааегіеі + , ЗООбрі и вывод на 
14 имя файла*. Получившийся файл печати имеет 
расширение .СОО. 

- скопировать файл печати имя файла .СОО в каталог па- 
кета РаіпіВшаН IV Ріиа и конвертировать этот файл в фор- 
мат .РСХ утилитой НР2РСХ.ЕХЕ. для этого следует ввести 
командную строку: НР2РСХ.ЕХЕ «имя файла .СОО» 

В результате будет создан файл «имя файла .РСХ» (далее 
именуемый картинкой). 

- вызвать цветной РаіпШгиаН и загрузить в него созданную 
картинку. При загрузке файла выбрать “Сопѵегі іо соіог*. 

Если окажется, что картинка имеет синий фон, то его 
следует превратить в белый. Для этого надо установить 
первичный цвет (ргішагу соіог) синим, вторичный цвет 
(аесопбагу соіог) белым, и, перемещая рабочее поле по полю 
картинки, дважды нажимать соіог егазег (пятый слева сверху 
инструмент на инструментальной панели). 

- выбрать в меню “Эіаріау* опцию “Зоііб соіога опіу* и 
залить желаемую область на картинке каким-либо цветом. 
Цвета соответствуют полутонам серого по увеличению 
черноты в следующем порядке: 

белый, желтый, светло-голубой, светло-серый, светло- 
зеленый, серо-голубой, светло-фиолетовый, коричневый, 
темно-зеленый, темно-серый, красный, темно-фиолето- 
вый, темно-красный, синий, темно-синий, черный. 


Впрочем, для некоторых цветов разница между соответст- 
вующим им полутонам серого трудно различима. После за- 
ливки нужно сохранить картинку, проверить ее размеры 
(“ЕсІІГ “СНапде епИге 1та$е* “8еі ипііа*) и покинуть цветной 
РаіпШгиаН; 

- вызвать черно-белый РаіпШгиаН и загрузить в него создан- 
ную цветную картинку. При загрузке картинки выбрать 
*8еі НаШопеа* и в появившемся диалоговом окне выбрать 
тип, яркость и частоту растра. 

Опыт подсказывает, что тип растровой сетки (НаІГіопе 
раііегп) *Ра1Нп$“ меньше всего подвержен дефектам при рас- 
печатке. Отпечатанная картинка при использовании этого 
растра напоминает обычную газетную фотографию (для раз- 
решения 300x300 точек на дюйм). Если использовать как 
фон графики, то получается очень похоже на фон обычного 
окна в “вентуре*. Тип “ШНиаеб* выглядит довольно привле- 
кательно — своим рисунком он напоминает тисненую бумагу, 
обычно более подвержен искажениям при распечатке, чем 
“Раіііп$“. Тип “ЕпНапсеб* похож на “ЦіГГиаесІ*, но рисунок 
его тоньше, а подверженность искажениям еще больше. Типы 
“Вауег* и “Нех Ьауег* очень похожи на фон “вентуровской* 
графики и столь же подвержены искажениям. 

Установка яркости (Ьгі^Ніпеаа) равной 128 или немного 
больше дает вполне приличный результат. Установка частоты 
растра (НаІГіопе асгееп аіге) 75 ЬРІ (Нпе рег іпсН —линий на 
дюйм) обычно тоже дает приличный результат. Рост величи- 
ны этого параметра делает рисунок растра тоньше, но и чувс- 
твительнее к искажениям при печати, а градации серого — 
менее различными. Однако изменения этого параметра вли- 
яют только на “Раіііпя*; 

- после того, как цветная картинка желаемым образом кон- 
вертирована в черно-белую, обязательно следует сохранить 
ее и покинуть редактор. В случае выхода без сохранения 
результаты конверсии будут потеряны; 

- теперь у нас есть черно-белая картинка, размеры ее нам из- 
вестны. Остается вновь загрузить Ѵепіиге, создать на месте 
графического окна обычное окно нужного размера и загру- 
зить в него нашу картинку. 

Эта же технология может быть полезна, при использова- 
нии для иллюстрирования издания копий экрана, “захвачен- 
ных* утилитой Ггеехе.ехе. Если такую копию загрузить в 
Ѵепіиге без предварительной обработки, то одни цвета прев- 
ратятся в черный, другие — в белый, в результате чего часть 
изображения станет неразличимой. Если же конвертировать 
эти цвета в полутона серого, то у Вас получится достаточно 
приличная иллюстрация. 

В. Каминский 
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Компьютерные взломщики все еще правят миром — 

так быть не должно 

Корреспонденты Ме\гсЪуіез Джон и Барбара Макмуллен 
сообщают, что американские компьютерные системы все 
еще очень уязвимы для нападения хакеров. Эммануэль 
Голдстейн, издатель 2600 Мадахіпе: ТЬе Наскег (}иаПег1у, 
заявил в Нью-Йорке, что “американская общественность 
часто дает себя убаюкать ложному чувству безопасности", 
для которого факты компьютерного взлома не дают ника- 
ких оснований. Он продемонстрировал записи того, как 
голландский хакер взламывал компьютеры армии США, а 
также показал, с какой легкостью можно проникнуть в 
компьютерные системы американских деловых и прави- 
тельственных учреждений. 

Датский взломщик завел фиктивного пользователя под 
именем “баіщиаіе" (вице-президент США Оап (?иа1е) и 
затем получил полный контроль над системой. Голдстейн 
сказал, что то, что важным пользователям дают очевидно 
угадываемые пароли типа “КиѵаіІ", вызывает серьезную 
тревогу. По его словам, взлом системы не причинил ника- 
кого ущерба. В нескольких случаях физического взлома 
было отмечено использование замка фирмы Зітріех всего 
лишь с 1,085 возможными комбинациями. Многих ни в 
чем не повинных людей винят за то, с какой легкостью от- 
крывается этот замок. 

Голдстейн сделал абсолютно правильное заявление. В 
течении многих лет американская политика в этом вопро- 
се сводилась к “преследованию" и “жестким" приговорам 
в отношение небольшого числа преступников, которые бы- 
ли пойманы, вместо использования элементарных методов 
предотвращения преступлений, которые могли бы оказать- 
ся дешевыми, легкими и эффективными. Причины, по ко- 
торым не сделано то, что нужно, несостоятельны как с мо- 
ральной, так и с финансовой точки зрения. 

ТНе Теіериііпв НоШпе, ОсіоЬег 24, 1991 

Новые лазеры дают ключ к плоским экранам 

Исследователи в американских университетах Ригсіие и 
Вгошп сообщили, что новые сине-зеленые лазеры могут 
сильно улучшить качество всех плоских дисплеев. Синие 
лазеры используют меньшую длину волны, чем красные. 
Их разработка проводилась на коммерческой основе для 
фирмы ЗМ. По словам исследователей при использовании 
этих лазеров на компакт-дисках и СЭ-КОМ (ПЗУ на ком- 
пакт-дисках) можно будет поместить в 4 раза больше дан- 
ных. Ключом к созданию синих лазеров стала молекуляр- 
ная лучевая эпитаксия, при которой ученые создают стру- 
ктуры на уровнях одного атома. Устройства, использую- 
щие эту технологию, могут появиться в течение одного 
года. 

ТНе ТеІериІіп& НоШпе, ОсіоЬег 24, 1991 

АТ АТ создает канал связи для домашних фирм 

АТ АТ создала АТАТ Ноше ОІПсе Кеідѵогк, первую суб- 
сидируемую корпорациями ассоциацию, поддерживаю- 


щую нужды людей, работающих дома. Чтобы стать чле- 
ном ассоциации, нужно чтобы ваш телефон был заабони- 
рован в АТАТ. Компания планирует взимать плату после 
одного года работы. Члены ассоциации получают ежеквар- 
тальный журнал, скидки на продукцию и услуги АТАТ и 
могут рассчитывать на более низкие цены у таких фирм, 
как Рапазопіс, ІІРЗ и др. АТАТ оценивает число амери- 
канцев, которые работают дома в своих личных фирмах, 
в 11.8 миллиона человек, причем ежегодный прирост со- 
ставляет 10%. 

ТНе Теіериііпх НоШпе, ОсіоЬег 24, 1991 

ШЗСОѴЕК будет телефонной карточкой для ЗРКІІЧТ 

Идя по стопам АТАТ, перешедшей на кредитные кар- 
точки, и МСІ, заключившей союз с Ѵі$а, ЗргіпІ подписала 
соглашение, в результате которого кредитная карточка 
Оізсоѵег фирмы Зеагз станет телефонной карточкой для 
телефонной сети ЗргіпІ, связывая базы данных, используе- 
мые обоими фирмами. Новая программа, названная Ѵаіие- 
РЬопе, предоставит пользователям Эіасоѵег некоторые 
скидки на звонки по сети ЗргіпІ, сделанные с помощью 
карточек. 

ТНе Теіериііпв НоШпе , ОсіоЬег 24, 1991 

МІЫЛОТОЕ представляет сотовые модемы СИЬС 

МіІІісІупе, компания, работающая в паре с МіНісот, 
анонсировала два сотовых модема, поддерживающих про- 
токол передачи Сеііиіаг Иаіа Ііпк Сопігоі — альтернативу 
МОТ 10 с коррекцией ошибок фирмы Місгосош. Протокол 
Сеііиіаг Оаіа Ііпк относится х риЫіс сіотаіп. СПЬС ис- 
пользуются сетью ѴосіаГопе в Великобритании. Согласно 
протоколу сначала формируются поля данных, а затем они 
передаются в кадрах, в которые добавляется поле синхро- 
низации, поле коррекции ошибок, чередование битов и се- 
лективная повторная передача. Модемы можно будет при- 
обрести в ноябре по цене 795 долларов за штуку. Они ра- 
ботают на скорости 2400 бод. МШШупе также будет по- 
ставлять фирмам, осуществляющим сотовую связь, обору- 
дование для отслеживания передаваемых данных и другие 
изделия. 

ТНе ТеІериІіп% НоШпе, ОсіоЬег 24, 1991 

Следует ждать в скором времени появления дешевых' 
модемов со скоростью передачи 14,400 бит в секунду — 
компания РНуІоп объявила, что ими создан набор из трех 
микросхем Ѵ.32ВІ8, который может осуществлять переда- 
чу как данных, так и факсимильных сообщений с такой 
скоростью, а также на всех более низких скоростях соглас- 
но международным стандартам ССГГТ. Новый набор мик- 
росхем включает в себя все, что нужно для обработки го- 
лосовой почты, регистрации звонков, маршрутизации фак- 
симильных сообщений и идентификации звонящего або- 
нента — даже в компьютере класса Іаріор. Ранние версии 
набора использовались в модемах фирмы Науез. Новые 
схемы стоят всего 50 долларов при оптовых закупках. 

ТНе Теіериііщ НоШпе, ОсіоЬег 17, 1991 

Несмотря на катастрофическое положение в области 
прав человека, Китай вызывает растущий интерес со сто- 
роны американских фирм, связанных с телекоммуникаци- 
ей. Недавно фирма Науез, производитель модемов, расши- 
рила свое производство, а Зргіпі объявила о контрактах, 
согласно которым в стране появятся ее служба передачи 
сообщений Теіешаіі и службы ЗргіпІМаіІ Х.400. Зргіпі сде- 
лала это объявление одновременно с сообщением о заклю- 
чении аналогичного соглашения с Тайванем. Тем време- 
нем агентство ЮПИ сообщило, что семь человек расстре- 
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ляно в Китае за кражу медного кабеля. Государственная 
газета Ье&аі Эаііу назвала такие кражи “сильно распрост- 
раненными “. 

ТНе Теіериііщ Ноіііпе, ОсіоЬег 17, 1991 

Семь региональных компаний Веіі хотят, чтобы нало- 
гоплательщики заплатили им от 300 миллионов до 1 мил- 
лиарда долларов, прежде чем они доведут волоконную 
связь до всех уголков страны. Таково заключение Рича 
Тома, президента фирмы Теісоштипісабопа Зоіибопз Гог 
Атегіса, основанное на результатах исследований, прове- 
денных для компаний Веіі такими фирмами, как АПЬиг 
О. ІіШе и Баіа Кезоигсез. 

Тома заявил, что эти субсидии запрашиваются помимо 
требований Веіі об отмене запрета на участие в предостав- 
лении информационных услуг, и сверх их запросов на за- 
мену используемой около века схемы “нормы прибыли “ 
на регулирование потолка цен. Субсидии могли бы 
принять форму налоговых льгот, быстрого списания 
действующего оборудования или прямой выплаты денег. 
Недостаток капиталовложений компаний Веіі в свои сети 


угрожает общей конкурентоспособности США, добавил 
Тома. “Зачем компаниям приобретать новую технологию, 
если МСІ Май тащится со своим модемом на 2,400 бод, 
или их модем йа 9,600 все время сваливается на более 
низкую скорость передачи", — сказал он. “Телефонные 
сети являются местными сетями, которыми пользуются 
все, и они находятся в плохом состоянии". Вместо того, 
чтобы их улучшать, добавил он, Веіі вкладывает деньги, 
полученные от абонентов, за рубежом, приобретая иност- 
ранные телефонные компании и концессии на сотовую 
связь, хотя обещают крупные капиталовложения, чтобы 
довести свои услуги до уровня стандартов XXI века. 

ТНе Теіериііпв Ноіііпе , ОсіоЬег 17, 1991 


Подписка на русскую версию Теіериііщ Ноіііпе 
открылась в сети электронной почты ЯЕЬСОМ. 

Теіериііщ Ноіііпе выходит дважды в неделю ( 1 выпуск 
объемом 10 Кбайт), редактируется в Атланте (США) 
и Лондоне, и стоит для абонентов Релкома всего 
85 рублей в меся и в отличие от американской версии, 
продающейся за (50. Русская версия Ноіііпе выходит в 
свет через пять часов после появления его за океаном. 


На этой странице помещен бланк заказа на журнал «КомпьютерПресс» 
Вы можете его вырезать и, заполнив, отправить нам по адресу: 
113093, Москва, а/я 37 


Подписка на 1992 г. принимается до 31 января 1992 г. Число экземпляров — без ограничений. 
Стоимость годовой подписки на “КомпьютерПресс" — 57 рублей 60 копеек. 

Деньги следует перечислить на расчетный счет агентства “КомпьютерПресс". 

Наши банковские реквизиты : 

получатель: Автобанк (для зачисления на счет №345708) 
расчетный счет получателя: №161202 

банк получателя: ЦОУ при Госбанке СССР. МФО №299112. 

Бланк заказа и заверенную копию платежного поручения или почтовую квитанцию о переводе денег 
на счет Агентства следует приложить к заказу. 

Без одновременной оплаты подписной стоимости заказ не принимается. 

ЗАКАЗ 
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Адрес 


(ПОЧТОВЫЙ ИНДЕКС УКАЗЫВАТЬ ОБЯЗАТЕЛЬНО) 

Прошу оформить подписку на журнал КомпьютерПресс на 1992 год 

Подписная плата в сумме перечислена 

платежным поручением (почтовым переводом) № 

от 199 г. 


(Копия платежного документа прилагается) 
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Советско-американское предприятие " Соваминко ” 
Рекламно-издательское агентство " КомпьютерПресс " 


Принимает заказы на журнал " КомпьютерПресс “ и 
производит отправку наложенным платежом. 


Заказ высылается по адресу: 1Ѳ1186, Ленинград, Невский проспект, 28, 

Магазин № 1 "Дом книги” 
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(почтовый индекс указывать обязательно) 


Номера выпусков . Количество экземпляров 
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Советско-американское предприятие 99 Соваминко 99 
Рекламно-издательское агентство 99 КомпьютерПресс" 


Принимает заказы на журнал 99 КомпьютерПресс 9 * и 
с/ производит отправку наложенным платежом. 


Заказ высылается по адресу: 630076, Новосибирск, Красный проспект, 60 
Магазин № 7 "Техническая книга” 

Телефон для справок: 20-05-09 
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Номера выпусков 


Количество экземпляров 



компьютером необходим посредник-программист? Вы работаете с программными продуктами 
только надежных, всемирно известных фирм? 

Электронная таблица ОІІАТТКО РКО 3.0 американской корпорации огіапё Іпіегпаііопаіпозволит 
Вам общаться с компьютером на «ты» и возьмет на себя всю тяжесть текущей работы. 
Любые бухгалтерские и экономические расчеты, возможность вести всю документацию предпри- 
ятия, встроенная издательская система и сложные отчеты типографского качества, деловая графи- 
ка и даже ідектронные слайдофильмы со звуковыми эффектами — завтра Вы не будете мыслить 
свою жизнь без ОІІАТТКО РКО. Спектр технических характеристик ОІІАТТКО РКО удивительно 
сочетается с неприхотливостью программы: даже на ІВМ РС/ХТ можно работать в графическом 
режиме, использовать автоувеличение фрагментов таблицы от 25 до 100%, печатать во всех мыс- 
лимых и немыслимых режимах, включая бесконечные графики на непрерывной ленте, подбирать 
оптимальную для глаз палитру красок и формировать содержимое меню. 

Стоимость пакета ОІІАТТКО РКО — 4000 рублей или 495 долларов США. 

Общение с ОІІАТТКО РКО приносит радость — приходите, и мы убедим Вас в этом. 

СП « Интерквадро » Москва, 2-й Новоподмосковный пер., 4. Телефон 150-92-01 
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МАКЛИНКЕР УНИВЕРСАЛЬНЫЙ 

автоматическое устройство для прокраса и 
восстановления лент матричных принтеров 
шириной до 24 мм. Обеспечивает 100% 
восстановление красящих свойств, что 
позволяет Вам продлить срок эксплуатации 
одной ленты в 30-50 раз при условии 
своевременного прокраса. В комплект 
поставки входит 1 литр тонера, 



обеспечивающий прокрас 2000 м 13-ти 
миллиметровой ленты. Поставка 
дополнительного тонера по желанию 
заказчика. 



”ВЕСНА-4” 

многофункциональное 
интеллектуальное устройство 
на базе однокристальной 
микроЭВМ — обеспечивает 
мгновенное определение номера 
звонящего абонента, а также 
предлагает пользователю 
множество сервисных удобств, 
вплоть до охранной квартирной 
сигнализации. 

МОДЕМ СОМРІЛ1ЧК-С4800 

для ІВМ РС АТ/ХТ, обеспечивает передачу 
информации на отечественных телефонных 
линиях со скоростью не менее 1200 бит/с 
на выделенных линиях — не менее 
4800 бит/с. 


Фирма КОМП — единственный в стране 
разработчик и производитель 
представленной продукции. 


Обеспечивает немедленную поставку 
и гарантийное обслуживание. 

Телефон: (095 ) 353-68 58 
с 1 1 до 18 часов 



КезеагсЬ сегйге СОМР ІТП 

109388, Ъ.28, Зіюззеіпауа зі., Мозсо\ѵ, ІІ88К. 



